Hola, en el codigo de mi aplicacion puse la sentencias par capturar las axcepciones al aplicar los cambios pero si intento ingresar un campo duplicado (en este caso el numero de factura) no tira ninguna excepcion, los datos no se cargan en la DB (hasta ahi bien), pero el registro se carga temporalmente en memoria!
Código:
try
TFacturas_cab.ApplyUpdates;
RFacturas_det.ApplyUpdates;
except
on E: Exception do
MessageDlg(PChar('Problem with updating: ' + E.Message),mtError, [mbOk],0);
end;
Esta es la estructura de la tabla
Código:
CREATE TABLE facturas_cab(
id_factura_cab INTEGER NOT NULL PRIMARY KEY,
nro_factura_cab VARCHAR UNIQUE NOT NULL,
cliente_id INTEGER,
clausula_id INTEGER,
foma_pago_id INTEGER,
fecha VARCHAR NOT NULL DEFAULT '01/01/1970',
importe_total NUMERIC(7,2) NOT NULL DEFAULT 0.00
);
Lo que yo espero es que tire una excepcion y que no cargue nada en memoria...
Por ultimo intente esto que si funciono, pero no me parece muy elegante puesto que ApplyUpdates puede devolver "false" por muchas razones...
Por ejemplo, al aplicar los updates de facturas_cab ejecuto esto
Código:
If not TFacturas_cab.ApplyUpdates then
begin
MessageDlg('Error al grabar la factura, verifique el numero de factura, mtError,[mbOk],0);
TFacturas_cab.Delete;
end;
La sentecia TFacturas_cab.Delete; la tengo que poner por que sino me deja el registro en memoria, o sea, si en un TDBGrid habia 3 filas, despues de cargar una factura con un numero duplicado, me quedan 4 filas, una, por supuesto, con el numero de factura duplicado. pero en la DB no se carga nada.
Gracias por la asistencia!