Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 17-11-2015
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
A pesar de la excepción, el registro se graba

Buenas. sigo a vueltas con los triggers; lo cierto es que en estos días he aprendido un montón de cosas. Gracias a todos los que me habéis ayudado.

Tengo una tabla en FB 2.5 con esta estrutura:
Código PHP:
CREATE TABLE Bancos (Codigo VARCHAR(4NOT NULLNombre VARCHAR(65), Bic VARCHAR(11), CONSTRAINT PK_Bancos PRIMARY KEY (Codigo)) 
E inserto los datos por ejemplo así:
Código PHP:
Query->Close();
Query->SQL->Text "INSERT INTO Bancos (Codigo, Nombre, Bic) VALUES (:Codigo, :Nombre, :Bic)";
Query->ParamByName("Codigo")->AsString "003";
Query->ParamByName("Nombre")->AsString "BANCO DE DEPOSITOS";
Query->ParamByName("Bic")->AsString "BDEPESM1XXX";
Query->ExecSQL(); 
El campo Codigo necesariamente tiene que tener cuatro posiciones. Para controlarlo he definido un trigger y una excepción así:
Código PHP:
CREATE EXCEPTION CodBan_erroneo 'El código de entidad es incorrecto. Verifíquelo.';

SET TERM ^ ;

CREATE TRIGGER BANCO_VERIFICA FOR BANCOS
ACTIVE BEFORE INSERT 
OR UPDATE
POSITION 0
AS
BEGIN
  
IF (INSERTING AND CHAR_LENGTH(TRIM(NEW.Codigo)) <> 4THEN
    EXCEPTION CodBan_erroneo
;
    
WHEN GDSCODE except DO BEGIN
    END
END 
^
SET TERM ; ^ 
Tengo también definido una función de gestión de errores. Al ejecutarse el query con esos datos lógicamente salta la excepción porque al código le falta una carácter.
  1. Si no pongo la claúsula WHEN salta el gestor de errores, el registro no se graba y se detiene la ejecución del programa.
  2. Si pongo la claúsula WHEN como está ahí ni salta el gestor de errores ni se detiene la ejecución y le registro sí se graba.
Sé que os estoy dando la paliza, pero por más docuemtación que he leído no veo como "combinar" las dos cosas; es decir: que salte la excepción, que no se grabe el registro erróneo y que continúe la ejecución del programa.
Responder Con Cita
  #2  
Antiguo 17-11-2015
Avatar de Osorio
Osorio Osorio is offline
Miembro
 
Registrado: may 2003
Ubicación: Colombia
Posts: 251
Poder: 21
Osorio Va por buen camino
Buenos dias,


Yo realmente nunca he utilizado el wehen GDSCODE xxx do para interceptar la excepcion del lado del motor de BD. Siempre la intercepto en delphi y luego determino que hacer pero desde delphi.

Sin embargo en la cara oculta de delphi 6 a partir de la pagina 246 tiene una explicacion de como se usa hasta con un ejemplo parece.

Bajate el libro en formato pdf de aca.

http://www.marteens.com/pdfs/TheDarkSideOfDelphi6.pdf
Responder Con Cita
  #3  
Antiguo 17-11-2015
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Muchas gracias. Tengo descargado La car oculta de C++ Builder; le echaré una ojeada al que me dices.
Responder Con Cita
  #4  
Antiguo 17-11-2015
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por Osorio Ver Mensaje
Yo realmente nunca he utilizado el wehen GDSCODE xxx do para interceptar la excepcion del lado del motor de BD. Siempre la intercepto en delphi y luego determino que hacer pero desde delphi.
He estado leyendo el manual que me indicabas y he comprobado que traemucha más información que el que yo tenía de la Cara oculta de C++, que es el lenguaje con que trabajo. Esto es secundario ya que se fácil pasar de uno a otro.

Desde que leí tu mensaje le he estado dando vueltas a tu comentario:
Cita:
Siempre la intercepto en delphi y luego determino que hacer pero desde delphi.
¿Cómo lo haces? ¿Puedes adjuntar algún código de ejemplo?
Responder Con Cita
  #5  
Antiguo 17-11-2015
cloayza cloayza is offline
Miembro
 
Registrado: may 2003
Ubicación: San Pedro de la Paz, Chile
Posts: 910
Poder: 22
cloayza Tiene un aura espectacularcloayza Tiene un aura espectacular
Te sugiero lo siguiente:

Código SQL [-]
CREATE EXCEPTION CodBan_erroneo 'El código de entidad es incorrecto. Verifíquelo.';

SET TERM ^ ;

CREATE TRIGGER BANCO_VERIFICA FOR BANCOS
ACTIVE BEFORE INSERT OR UPDATE
POSITION 0
AS
BEGIN
  IF (INSERTING AND CHAR_LENGTH(TRIM(NEW.Codigo)) <> 4) THEN
    EXCEPTION CodBan_erroneo;

    WHEN EXCEPTION CodBan_erroneo DO 
    BEGIN
              --Acá puedes controlar el error o dispararlo nuevamente...
              EXCEPTION CodBan_erroneo;
    END
END ^

Saludos cordiales
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
Continuar Procedure a pesar del salto de excepción santiaguinillo Firebird e Interbase 13 11-06-2008 15:33:36
Por que no graba en Win.ini alquimista API de Windows 11 23-04-2008 01:20:01
Pronostico extendido: El foro en aprox 12 dias va a pesar unos kilos más... Delphius La Taberna 3 09-03-2007 00:27:54
FireFox sigue avanzando a pesar de perder popularidad en España Sasuke_Cub Noticias 3 23-05-2006 03:28:27
Firebirds siempre devuelve un registro, a pesar... Nose Firebird e Interbase 8 17-05-2004 18:43:27


La franja horaria es GMT +2. Ahora son las 04:09:55.


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