Utilizamos cookies propias y de terceros. [Más información sobre las cookies].
Política de cookies
Proyecto AjpdSoft

· Inicio
· Buscar
· Contactar
· Cookies
· Descargas
· Foros
· Historia
· Nosotros
· Temas
· Top 10
· Trucos
· Tutoriales
· Wiki
Proyecto AjpdSoft: Foros

AjpdSoft :: Ver tema - Error Duplicate entry en Delphi y MySQL - Capturar
Foros de discusión Buscar Perfil FAQ Iniciar sesión
Information Error Duplicate entry en Delphi y MySQL - Capturar

Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net   
Ver tema anterior :: Ver tema siguiente
AutorMensaje
varios
Magnífico usuario


Registrado: Oct 10, 2006
Mensajes: 2092

Asunto: Error Duplicate entry en Delphi y MySQL - Capturar Responder citando

Me aparece este error cuando intento dar de alta un registro en una base de datos MySQL:


---------------------------
Contabilidad y facturación
---------------------------
SQL Error: Duplicate entry 'Fernando' for key 2.
---------------------------
Aceptar
---------------------------


El error sé a qué se debe (duplicidad de clave primaria o única). Lo que quiero, si se puede, es poder mostrar otro mensaje de error un poco más entendible por el usuario ¿se puede capturar este error y mostrar otro?

Utilizo Delphi como lenguaje de programación y MySQL como base de datos. Para el acceso a MySQL utilizo ZeosDBO, en concreto un TZTable.
MensajePublicado:
Jue May 03, 2007 3:38 pm
Top of PageVer perfil de usuario
alonsojpd
Administrador/Moderador


Registrado: Sep 16, 2003
Mensajes: 2687

Asunto: Re: Error Duplicate entry en Delphi y MySQL - Capturar Responder citando



Anuncios



varios escribió:
Me aparece este error cuando intento dar de alta un registro en una base de datos MySQL:


---------------------------
Contabilidad y facturación
---------------------------
SQL Error: Duplicate entry 'Fernando' for key 2.
---------------------------
Aceptar
---------------------------


El error sé a qué se debe (duplicidad de clave primaria o única). Lo que quiero, si se puede, es poder mostrar otro mensaje de error un poco más entendible por el usuario ¿se puede capturar este error y mostrar otro?

Utilizo Delphi como lenguaje de programación y MySQL como base de datos. Para el acceso a MySQL utilizo ZeosDBO, en concreto un TZTable.



Para capturar este error de clave duplicada, debes utilizar el evento OnPostError del TZTable. Seleccionas el componente TZTable, abres la ventana de propiedades, pulsas sobre la segunda pestaña "Events" y haces doble clic sobre "OnPostError". El código fuente que puedes añadir en este evento es el siguiente:

Código:

procedure Tmd.tFacturaPostError(DataSet: TDataSet; E: EDatabaseError;
  var Action: TDataAction);
begin
  if e is EZDatabaseError then
  begin
    case EZDatabaseError(E).ErrorCode of
      1062 : begin
        MessageDlg ('Ya existe una factura con este número.',
            mtWarning,[mbok],0);
      end;
     else
        MessageDlg ('Se ha producido un error al intentar guardar el registro:' +
            chr(13) + chr(13) + inttostr(EZDatabaseError(E).ErrorCode) +
            ' -> ' + E.Message, mtInformation,[mbok],0);
    end;
    Action := daAbort;
  end;
end;


De esta forma podrás capturar cualquier error que se produzca y mostrar un mensaje de error personalizado.
MensajePublicado:
Sab May 12, 2007 8:07 am
Top of PageVer perfil de usuario
Mostrar mensajes de anteriores:   
Todas las horas son GMT - 1 Horas
Publicar nuevo tema Responder al tema
Foros de discusión » Borland Delphi, Codegear Delphi .Net  

Cambiar a:  
Key
  Puede publicar nuevos temas en este foro
No puede responder a temas en este foro
No puede editar sus mensajes en este foro
No puede borrar sus mensajes en este foro
No puede votar en encuestas en este foro
Visita nuestro nuevo sitio web con programas y contenidos actualizados: Proyecto A