Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Capturar error de Conexión con las IB (https://www.clubdelphi.com/foros/showthread.php?t=42593)

Manuel 17-04-2007 23:48:11

Capturar error de Conexión con las IB
 
Hola amigos del Club, estoy dejando atras las ttable (cambiando por la pestaña Interbase (IB, Creo) en delphi 5) para conectarme a una base de datos INTERBASE que además estoy migrando a FIREBIRD 2.0, el tema es el siguiente tengo una base de datos que la conecto con el objeto TIBEDataBase, todo bien uso query IB, todo bien le paso el nombre y la ruta de la base de datos física de esta manera:

Código Delphi [-]
procedure TDm.IBDatosBeforeConnect(Sender: TObject);
begin
     IBDatos.DatabaseName := 'E:\bddsistemas\DatosSanignacio\colacion.GDB';
end;

Ahora, en una aplicación más sofiticada esa ruta debería estar en un archivo configuración, como .ini que se yo, por defenir, mi pregunta concreta es que pasa si esa ruta no corresponde a la realidad, la aplicación me reportaría un error, mas seguiría con la ejecución, como podría capturar el error?, generar mi propio mensaje y terminar la aplicación. Algo trate con try .. except, pero no logro saber donde lo puedo colocar. Agradesco desde ya su ayuda.

luisgutierrezb 18-04-2007 01:02:22

pues se colocaria donde intentes conectar, puede ser por ejemplo en un splash window al iniciar la aplicacion, puede ser al crearse el form principal, etc

Manuel 20-04-2007 16:07:30

Cita:

Empezado por Manuel
Hola amigos del Club, estoy dejando atras las ttable (cambiando por la pestaña Interbase (IB, Creo) en delphi 5) para conectarme a una base de datos INTERBASE que además estoy migrando a FIREBIRD 2.0, el tema es el siguiente tengo una base de datos que la conecto con el objeto TIBEDataBase, todo bien uso query IB, todo bien le paso el nombre y la ruta de la base de datos física de esta manera:

Código Delphi [-]
procedure TDm.IBDatosBeforeConnect(Sender: TObject);
begin
     IBDatos.DatabaseName := 'E:\bddsistemas\DatosSanignacio\colacion.GDB';
end;

Ahora, en una aplicación más sofiticada esa ruta debería estar en un archivo configuración, como .ini que se yo, por defenir, mi pregunta concreta es que pasa si esa ruta no corresponde a la realidad, la aplicación me reportaría un error, mas seguiría con la ejecución, como podría capturar el error?, generar mi propio mensaje y terminar la aplicación. Algo trate con try .. except, pero no logro saber donde lo puedo colocar. Agradesco desde ya su ayuda.

Parece que plantee mal mi pregunta pero ahí va de nuevo:

Mi idea es, como capturo el error por una conexión fallida, algo como esto, que me funciona muy bien:

Código Delphi [-]
procedure TDm.IBDatosBeforeConnect(Sender: TObject);
var
  sPath: string;
begin
   sPath := 'E:\bddsistemas\DatosSanignacio\colacion.GDB';
   if not FileExists(sPath) then
      begin
        ShowMessage('No se encuentra la base de datos '+sPath+' por lo tanto finalizará la sesión');
        Application.Terminate;
        exit;
      end;  
     IBDatos.DatabaseName := sPath;

end;

ahora que pasa si la base de datos colacion.GDB, esta corrompida o simplemente no es un base de datos interbase?, mi pregunta es como capturo ese error, por que en estos momentos solo capturo el error si el archivo colacion.gdb no se encuentra en el directorio especificado. Gracias.

Lepe 20-04-2007 19:33:38

Antes de nada definimos nuestros tipos de Excepciones.

Después solo tenemos que crearlas y lanzarlas cuando más nos apetezcaa con
raise NOMbreExcepcion.Create(mensaje a mostrar)

Por último en un TApplictionEvents, en su evento OnException, averiguamos que tipo de excepción es y actuamos en consecuencia, grabando un archivo .txt la clase de excepción y la descripción.

Código Delphi [-]
type EShowException = class Exception;
       EFatalException = class Exception;
       EHiddenException = Class Exception;

procedure TDm.IBDatosBeforeConnect(Sender: TObject);
var
  sPath: string;
begin
   sPath := 'E:\bddsistemas\DatosSanignacio\colacion.GDB';
   if not FileExists(sPath) then
      begin
raise EFatalException.Create ('No se encuentra la base de datos '+sPath+' por lo tanto finalizará la sesión');
      end;  
     IBDatos.DatabaseName := sPath;
end;


procedure TFormPrincipal.ApplicationEventsOnException(....E:Exception);
begin
  GrabarAArchivoLog(E.ClassName, E.Message);
  if E is EFatalException then
  begin
    ShowMessage E.message);
    Application.Terminate;
  end
  else if E is EShowException then
   ShowMessage(E.Message);
  else if E is EHideException then
  // juas no hacemos nada y no la mostramos al usuario, 
//solo la grabamos en el archivo de texto
end;

El tema de EHideException es muy subjetivo, yo lo uso con aquellos fallos tontos y que suelo controlar como '' is not a valid integer, la fecha introducida no es válida, etc. En esos casos suelo mostrar un mensaje al usuario dándole ayuda en español, pero aparte, suelo lanzar la excepción para:
- Que se corte el flujo normal del programa y no ejecute código con una fecha inválida
- Que se guarde la excepción en el archivo de texto, para cuando vaya a modificar algo, ver los tipos de errores que suele cometer el usuario.

En delphi 6, cuando se lanza una excepción siempre se muestra al usuario, aunque tengamos un TApplicationEvents.

En BDS 2006, cuando se lanza una excepción y existe el TApplicationEvents.OnException, la excepción no se muestra al usuario final, por ello, he puesto ShowMessages dentro de dicho manejador.

La forma de mostrar la excepción al usuario, ya es estilo propio, ShowMessage, MessageBox, etc.;

Edito:

Los try ... except se deberían poner donde quiera que pueda producirse un error, pero claro, son muchos puntos en una aplicación mediana, por tanto, puedes controlar algunos directo en el código, y el resto en el ApplicationEvents.OnException.

El flujo normal de excepciones es:
- Se produce una excepción, si está entre un try ... except:
Se salta directamente a ese except y se ejecutan las líneas que haya, después se continúa en al final del except....end.
Si dentro del except..ende hay una instrucción raise;, la misma excepción que ha saltado, se vuelve a lanzar, si hay un ApplicationEvents, llegará hasta él.
- Se produce una excepción, no hay ni try...except ni tampoco un ApplicationEvents:
Se corta el flujo del programa en esa línea de código y se muestra al usuario el mensaje de la excepción.

Saludos

LordRiper 20-04-2007 20:56:19

Prueba con esto:

Código Delphi [-]
try
  DB.Connected:=True;
except
  On E:Exception do
  begin
    Mensaje('Error al conectar con la Base de Datos, error regresado por el servidor: '+E.Message);
  end;
end;


La franja horaria es GMT +2. Ahora son las 23:18:21.

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