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 30-10-2007
egarc egarc is offline
Miembro
 
Registrado: jul 2006
Posts: 60
Poder: 18
egarc Va por buen camino
Question Control Transaccional

Buenas, uso ADO con SQL SERVER 2005 y DELPHI 2007 for WIN32, lo que quiero hacer es lo siguiente:
tengo un formulario de EMISION DE FACTURAS, o mejor dicho un MASTER DETAIL, los datos los grabo ejecutando una sentencia para grabar el MAESTRO, y otra sentencia que se ejecuta con un ciclo desde el primer detalle hasta el último para grabar los DETALLES., pero mi problema es que si hay un error en SQL al momento de grabar el detalle, o por cualquier motivo, no se grabó el detalle, ya he grabado en el MAESTRO, y entonces tengo facturas que no tienen detalle.

Quiero saber cómo puedo grabar toda la transacción, o no grabar nada si ocurre un error. O como puedo hacer una sola transacción que grabe en el maestro y grabe en el detalle.

Cualquier comentario se los agradeceré.

Sin otro particular....gracias anticipadas.!
Responder Con Cita
  #2  
Antiguo 30-10-2007
Avatar de poliburro
[poliburro] poliburro is offline
Miembro Premium
 
Registrado: ago 2004
Ubicación: México D.F
Posts: 3.068
Poder: 23
poliburro Va por buen camino
Yo te aconsejo usar procedimientos almacenados que incluyan el bloque


Begin tran


Commit Tran


Y haciendo uso de la variable de estado @@Error, evaluar si debes hacer un rollback Tran.

Ahroa que si lo quieres hacer con ADO.

pues le das

TAdoConnection.BeginTran


y al final de la sentencia

commit

y en un except le das Rollback.

Santas soluciones.
__________________
Conoce mi blog http://www.edgartec.com
Responder Con Cita
  #3  
Antiguo 31-10-2007
egarc egarc is offline
Miembro
 
Registrado: jul 2006
Posts: 60
Poder: 18
egarc Va por buen camino
Question

Por favor, alguien podria darme un ejemplo de un procedimiento almacenado que inserte un registro en el MASTER y X regsitros en el DETAIL, y que al final me devuelva un número de registro o de factura en mi caso..

Gracias anticipadas por sus 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
Que control usar Marit C++ Builder 1 20-09-2007 12:42:46
Control-C SMTZ Varios 1 23-11-2004 13:16:35
Replicacion Transaccional infomac MS SQL Server 0 23-03-2004 10:50:46
Replicacion Transaccional ...HELP ingel SQL 0 03-09-2003 21:03:00
Control que crea control craven OOP 5 07-06-2003 02:23:13


La franja horaria es GMT +2. Ahora son las 08:19:34.


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