![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
|
Un query que se cierra solo
Estoy usando Firebird con C++ 6. Tengo este código con dos TIBQuery:
Código:
Query->Close();
Query->SQL->Text = "INSERT INTO Cuentas (Padre, Cuenta, Defecto)
VALUES (:Padre, :Cuenta, :Defecto)";
qTemp->Close();
qTemp->SQL->Text = "SELECT DISTINCT A.Padre, B.Cuenta, B.Defecto
FROM ALU_TEMP A, CUE_TEMP B WHERE A.Referencia||A.Recibo = B.Referencia";
qTemp->Open();
for (; !qTemp->Eof; qTemp->Next())
{
if (!tColegio->InTransaction)
tColegio->StartTransaction();
Query->Close();
Query->ParamByName("Padre")->AsInteger = qTemp->FieldByName("Padre")->AsInteger;
Query->ParamByName("Cuenta")->AsString = qTemp->FieldByName("Cuenta")->AsString;
Query->ParamByName("Defecto")->AsInteger = qTemp->FieldByName("Defecto")->AsInteger;
try
{
Query->ExecSQL();
tColegio->Commit();
}
catch(...)
{
tColegio->Rollback();
}
}
He probado, en vez de un bucle, a hacer un INSERT masivo:
y me da un error de violacion de claves (la tabla está indexada por padre y cuenta). ¿A alguien se le ocurre alguna idea? Última edición por ecfisa fecha: 19-10-2013 a las 10:42:53. Razón: Cambiar etiqueta [code] por [sql] |
|
#2
|
||||
|
||||
|
Creo que el problema es que cuando guardas un registro debes hacer post, ya que el commit lo cierra.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#3
|
||||
|
||||
|
Cita:
El método Commit() almacena todas las operaciónes pendientes de la transacción actual y la cierra, por lo que deberías habrirla nuevamente si deseas continuar con las operaciones. Así mismo, el método Rollback(), cancela todas las operaciones pendientes de la transacción actual y la cierra. También deberías abrirla nuevamente si deseas continuar operando con ella. Existe la alternativa de usar CommitRetaining() y RollbackRetaining() que respectivamente almacenan y cancelan las operaciones, pero mantienen abierta la transacción actual. Saludos ![]() Edito: Como dijo Casimiro arriba. (no lo había visto... )
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 18-10-2013 a las 18:30:34. |
|
#4
|
||||
|
||||
|
Gracias a los dos. Ahora mismo lo pruebo.
|
|
#5
|
||||
|
||||
|
Perfecto. Lo que no acabo de entender es por qué no fuciona el INSERT masivo, pero dado que ya se ha solucionado.
|
|
#6
|
||||
|
||||
|
Cita:
Creo recordar que la sentencia es así:
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#7
|
||||
|
||||
|
No. El problema tiene que ser otro porque en ese mismo proceso de carga tengo otra tabla con la sintaxis que yo ponía:
y no me da error; además, el error es un problema de índices. No obstante ya está solucionado con el bucle. |
|
#8
|
||||
|
||||
|
Entonces es que en la tabla origen tienes 2 registros con el mismo valor y en la de destino no están permitidos repetidos.
Problema en los datos.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
|
#9
|
||||
|
||||
|
Efectivamente.
|
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Delphi 2007 se Cierra Solo | DANY | Varios | 3 | 21-03-2012 17:03:08 |
| mostrar un registro solo de un query | Patricio | Varios | 3 | 18-11-2008 20:31:27 |
| query no Graba , se cierra | juanmaster | Tablas planas | 9 | 12-12-2006 23:52:21 |
| Me cierra Delphi totalmente al activar Query | JamesBond_Mx | SQL | 2 | 12-01-2006 15:47:39 |
| los query son dataset de solo lectura? | kryna | SQL | 3 | 04-04-2005 01:22:27 |
|