Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 08-05-2007
Ezecool Ezecool is offline
Miembro
 
Registrado: jul 2003
Ubicación: Argentina
Posts: 60
Poder: 21
Ezecool Va por buen camino
Consulta sobre transacciones

Hola amigos, quisiera que me aconsejen sobre el uso de transacciones, mi duda surge al realizar actualizaciones en tablas en las que si un registro falla al actualizarse, simplemente lo descarto y continuo con el siguiente, estoy haciendo lo siguiente:

Código Delphi [-]
while not (tabla1.eof) then
begin
   Update_Tabla2.Connection.BeginsTrans;   
   try
     Update_Tabla2.Parameters.ParamByName('PSueldo').Value := 
        Tabla1.Sueldo * 1,10;
     Update_Tabla2.ExecSql;
     Update_Tabla2.Connection.CommitTrans;
   Except
     Update_Tabla2.Connection.RollBackTrans;
   end;
   Tabla1.Next;
end;
Esta bien que abra una transaccion por cada registro que quiero actualizar, no consume muchos recursos o tiempo esta tecnica? Muchas gracias

EDITADO: (Neftalí) Añado los TAG's.
__________________
Se vemos!

Última edición por Neftali [Germán.Estévez] fecha: 08-05-2007 a las 17:43:11.
Responder Con Cita
  #2  
Antiguo 08-05-2007
Avatar de juanlaplata
juanlaplata juanlaplata is offline
Miembro
 
Registrado: ene 2007
Ubicación: La Plata, Bs. As. (Argentina)
Posts: 212
Poder: 18
juanlaplata Va por buen camino
Piensa lo siguiente, cual es el sentido de una transaccion, para que es el comit y el rollback. La respuesta a esto se asemeja a lo que haces pero no en todo su criterio.
Una transaccion se le da commit si se realiza en su totalidad, en tu caso creo que la totalidad de la transaccion seria que actualize todos los registros y no una parcialidad. Si ocurre un problema en el proceso de actualizacion esta el rollback para el rescate.
Creo que deberias comenzar la trans. junto con el Try fuera del Loop.
Responder Con Cita
  #3  
Antiguo 08-05-2007
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.286
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Por favor utiliza TAG's cuando añadas código delphi a los mensajes.
Resulta mucho más lejible.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #4  
Antiguo 08-05-2007
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.286
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por Ezecool
Esta bien que abra una transaccion por cada registro que quiero actualizar?
Depende del ámbito que quieras para la transacción; Si se trata de un único registro creo que no hace falta, porque si falla la actualización en ese registro ya no se actualizará.
Si quieres que se actualicen todos los registros o ninguno, en ese caso debes sacarlo fuera como ya te han dicho.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
consulta sobre .ini bytecero Varios 2 02-02-2005 21:01:09
dudas sobre transacciones..... inexperto Conexión con bases de datos 2 18-11-2004 20:24:31
Duda sobre Transacciones Tama MS SQL Server 3 16-06-2004 10:58:05
consulta sobre consulta superhopi SQL 2 16-05-2003 19:01:47


La franja horaria es GMT +2. Ahora son las 12:28:48.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi