Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 11-02-2004
Isaac Isaac is offline
Miembro
 
Registrado: feb 2004
Ubicación: Ferrol
Posts: 77
Poder: 21
Isaac Va por buen camino
Control de errores en bd

Me gustaría saber las excepciones que hay en cuanto a bases de datos con el try. En particular me interesan las de cuando se intenta borrar un registro cuya clave es clave foránea (sin integridad referencial), o cuando lo intento con un registro que no existe. Sé que es:
try
adqquery.execsql
...
except
ahora irían las excepciones, que no me las sé
end;
Responder Con Cita
  #2  
Antiguo 11-02-2004
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
errores BDE, IB ¿?
Responder Con Cita
  #3  
Antiguo 11-02-2004
Isaac Isaac is offline
Miembro
 
Registrado: feb 2004
Ubicación: Ferrol
Posts: 77
Poder: 21
Isaac Va por buen camino
Errores en consultas SQL. Yo uso ACCESS y MYSQL
__________________
Me llamo Iñigo Montoya. Tú mataste a mi padre. Prepárate a morir

Mi foro: http://gandalfmithrandir.foro.st
Responder Con Cita
  #4  
Antiguo 11-02-2004
Avatar de marto
marto marto is offline
Miembro
 
Registrado: may 2003
Ubicación: Barcelona, Catalunya
Posts: 882
Poder: 22
marto Va por buen camino
Haciendo un borrado de un registro se pueden producir multitud de errores, pero como te comenta Lepe, el sistema que uses para acceder a tu BD es fundamental. En cualquier caso, el sistema de control de errores de Delphi no es la chapuza de VB. Si se produce calquier excepición en tu código, esta cortará el flujo de ejecución hasta que encuentre un bloque try que la controle. En ese momento se ejecutará lo que tengas en el except del bloque. Por ejemplo

Código:
try
  algo_que_produce_error;
except
  ShowMessage('trata de arrancarlo Carlos!!!!');
end;
se mostrará el mensaje se produzca el error que sea. Si quieres capturar cualquier excepcion y saber información del error puedes hacer lo siguiente:

Código:
try
  algo_que_produce_error;
except
  on E: Exception do
    ShowMessage(E.Message);
end;
Esta técnica te permite capturar en E cualquier excepción del tipo Exception, es decir qualquiera. E apunta a la excepción, por lo tanto puedes acceder a sus propiedades.
Si quieres capturar sólo un tipo de excepción puedes hacer algo así:

Código:
try
  algo_que_produce_error;
except
  on E: EDBException do 
    ShowMessage(E.Message);
  else
    raise;
end;
Este ejemplo captura las excepciones de tipo EDBException (que es una clase que hereda de Exception) y muestra su mensaje, si se produce otro tipo de excepción, la relanza.
__________________
E pur si muove
Responder Con Cita
  #5  
Antiguo 12-02-2004
Isaac Isaac is offline
Miembro
 
Registrado: feb 2004
Ubicación: Ferrol
Posts: 77
Poder: 21
Isaac Va por buen camino
Muchas gracias por responder
__________________
Me llamo Iñigo Montoya. Tú mataste a mi padre. Prepárate a morir

Mi foro: http://gandalfmithrandir.foro.st
Responder Con Cita
  #6  
Antiguo 17-02-2004
ronson ronson is offline
Miembro
 
Registrado: feb 2004
Posts: 100
Poder: 21
ronson Va por buen camino
NO ME VAN LAS EXCEp

Hola amigos yo he puesto lo siguiente:



MAinForm.DBGlobal.Params.Values['USERNAME'] := txtNombre.Text;
MAinForm.DBGlobal.Params.Values['PASSWORD'] := txtPassword.Text;
conexion.Visible:=false;

try
MAinForm.DBGlobal.Open;
except
ShowMessage('Error abriendo la base de datos: cerrando aplicación');
Application.Terminate;
end;


Y resulta que cuando el usuario o el password no son correctos el ODBC me da un error pero no me acepta la exception, es decir no me sale el mensaje ERROR ABRIENDO LA BASE DE DATOS.....

MI BASE DE DATOS ES FIREBIRD.


SALUDOS.
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


La franja horaria es GMT +2. Ahora son las 10:51:05.


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