Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > Lazarus, FreePascal, Kylix, etc.
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-09-2010
razor7 razor7 is offline
Miembro
 
Registrado: abr 2007
Posts: 30
Poder: 0
razor7 Va por buen camino
TDataSet Verificar registro duplicado

Hola, estoy intentando hacer que un TSqlite3DataSet impida la insercion de registros duplicados puesto que se trata de facturas.

Lo que se me ocurrio (soy muy nuevo en esto, perdon por las burradas) es checkear el evento "BeforePost" pero no he tenido suerte. El codigo es el siguiente, y el problema es que no cancela el post en cambio me crea igual un registro que queda completamente en blanco...

En resumen, lo que yo espero es que no quede ningun rastro del registro, pero en vez de eso, me deja un registro con sus campos completamente vacios

Código:
procedure TForm.TFacturas_cabBeforePost(DataSet: TDataSet);
var
  query: String;
begin
  query:='SELECT COUNT(nro_factura_cab) FROM facturas_cab WHERE nro_factura_cab='+QuotedStr(TFacturas_cabnro_factura_cab.Value);
  if not (TFacturas_cab.QuickQuery(query)='0') then
  begin
    TFacturas_cab.Cancel;
    MessageDlg('Esta factura ya existe!', mtError,[mbOk],0);
  end;
end;
Gracias por la ayuda!
Responder Con Cita
  #2  
Antiguo 02-09-2010
razor7 razor7 is offline
Miembro
 
Registrado: abr 2007
Posts: 30
Poder: 0
razor7 Va por buen camino
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!
Responder Con Cita
  #3  
Antiguo 02-09-2010
razor7 razor7 is offline
Miembro
 
Registrado: abr 2007
Posts: 30
Poder: 0
razor7 Va por buen camino
Bueno parece que el problema estaba en que tenia que usar "Abort" en vez de "Facturas_cab.Cancel", cambiado eso, anda perfecto...

Código:
procedure TdmPackingList.TFacturas_cabBeforePost(DataSet: TDataSet);
var
  query: String;
begin
  if TFacturas_cab.State in [dsInsert] then
  begin
    query:='SELECT COUNT(nro_factura_cab) FROM facturas_cab WHERE nro_factura_cab='+QuotedStr(TFacturas_cabnro_factura_cab.Value);
    if not (TFacturas_cab.QuickQuery(query)='0') then
    begin
      MessageDlg('Esta factura ya existe!', mtError,[mbOk],0);
      Abort;
    end;
  end;
end;
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
Copiar informacion de un Tdataset a otro Tdataset joelphi Varios 10 19-02-2009 22:27:44
Verificar registro con trigger fedelphi Firebird e Interbase 3 20-12-2006 12:57:43
como capturar error de registro duplicado ajmr81 Firebird e Interbase 3 17-10-2006 10:36:07
Registro Duplicado En Query jmedina SQL 2 29-11-2004 22:11:47
Registro Duplicado jmedina Conexión con bases de datos 0 17-11-2004 19:53:34


La franja horaria es GMT +2. Ahora son las 04:14: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