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 Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 09-11-2007
Avatar de JoseAntonio
JoseAntonio JoseAntonio is offline
Miembro
 
Registrado: abr 2006
Ubicación: Lima - Ciudad de los Reyes.
Posts: 87
Poder: 19
JoseAntonio Va por buen camino
Obtener el nombre de la tabla desde un trigger

Hola, necesito obtener en Firebird, desde el codigo del trigger, el nombre de la tabla a la que pertenece el trigger, alguien conoce alguna constante o variable que me de esa informacion? lo necesito asi por que el trigger sera copiado a muchas otras tablas y me facilitaria la tarea, gracias saludos.
__________________
nuestro carácter está reflejado en cada línea de código que escribimos.
Responder Con Cita
  #2  
Antiguo 09-11-2007
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Pues no lo sé.

Se me ocurre usar un programa delphi con un IBScript, desde allí sería muy fácil incluir esa variable y ejecutar el Script dentro de un bucle (creando físicamente los trigger en la BD).

Los nombres de las tablas podrías sacarlo del objeto TDatabase, mira sus métodos con el code insight.

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #3  
Antiguo 09-11-2007
Avatar de jhonny
jhonny jhonny is offline
Jhonny Suárez
 
Registrado: may 2003
Ubicación: Colombia
Posts: 7.058
Poder: 30
jhonny Va camino a la famajhonny Va camino a la fama
Bueno, tambien si hacemos una simple consulta a RDB$TRIGGERS podriamos traer ese dato asi:

Código SQL [-]
select RDB$RELATION_NAME from RDB$TRIGGERS where RDB$TRIGGER_NAME='Nombre_del_trigger'
__________________
Lecciones de mi Madre. Tema: modificación del comportamiento, "Pará de actuar como tu padre!"

http://www.purodelphi.com/
http://www.nosolodelphi.com/
Responder Con Cita
  #4  
Antiguo 09-11-2007
Avatar de JoseAntonio
JoseAntonio JoseAntonio is offline
Miembro
 
Registrado: abr 2006
Ubicación: Lima - Ciudad de los Reyes.
Posts: 87
Poder: 19
JoseAntonio Va por buen camino
Cita:
Empezado por jhonny Ver Mensaje
Bueno, tambien si hacemos una simple consulta a RDB$TRIGGERS podriamos traer ese dato asi:

Código SQL [-]

select RDB$RELATION_NAME from RDB$TRIGGERS where RDB$TRIGGER_NAME='Nombre_del_trigger'

Es posible... sin embargo como obtengo el nombre del trigger desde el codigo del mismo trigger?
__________________
nuestro carácter está reflejado en cada línea de código que escribimos.
Responder Con Cita
  #5  
Antiguo 10-11-2007
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 30
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Smile

¡Hola a todos!

Cita:
Empezado por JoseAntonio Ver Mensaje
Es posible... sin embargo como obtengo el nombre del trigger desde el codigo del mismo trigger?
Bueno, si ya estás dentro del disparador ("trigger" es disparador en inglés), se supone entonces que conoces su nombre nombre.

¿Será que tienes un procedimiento almacenado al que llamas desde disparadores de diferentes tablas, y es dentro de él donde necesitas el dato? Si ese es el caso, la solución sería que el procedimiento reciba un parámetro indicando el nombre de la tabla en cuestión.

Aunque sería muy chévere que desde cualquier procedimiento pudiéramos saber si estamos o no en el contexto de un disparador y el nombre de éste. Más concretamente, qué tabla "ha llamado" a nuestro procedimiento.

Ignoro si alguna base de datos tiene esa capacidad.

No dejes de exponer los progresos del caso.

Al González.
Responder Con Cita
  #6  
Antiguo 10-11-2007
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Yo insisto en mi método, ya que sería extremadamente fácil, te pongo un ejemplo con generadores, que es más cortito:

Código Delphi [-]
const sql = ' Create generator id%s ; ';
var Tablas:TStringlist;
      i:integer;
begin
  tablas := TSTringlist.create;
  database1.GetTablenames(tablas);
  for i:=0 to tablas.count-1 do
    script1.script.add(Format(sql, [tablas[i]]);

  script1.Execute; // hecho, creados tantos generadores como tablas tengamos
  tablas.free;
end;

El script quedaría así:
Código SQL [-]
Create generator idNombretabla1 ; 
Create generator idNombretabla2 ; 
Create generator idNombretabla3 ; 
Create generator idNombretabla4 ;

En lugar de añadir las cosas directamente al script, podemos tener un memo, donde verificamos las cosas e incluso podamos añadir más sentencias.

En este programa solo necesitas un Tdatabase, un transaction y tu ventana principal con el memo.

Tendrías las mismas posibilidades que en IB Expert, creando, eliminando triggers, etc.

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
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
Obtener el nombre de las conexiones de red aram2r Internet 0 01-08-2007 18:59:55
Obtener el nombre de la tabla jzginez Conexión con bases de datos 1 18-08-2006 23:32:03
Obtener el nombre del Adaptador de Red wpolanco Redes 0 17-05-2006 06:16:01
Como puedo obtener el nombre de tabla(s) de una bd access ctronx Tablas planas 6 05-11-2004 19:19:36
obtener valor en un trigger cesar_picazo Conexión con bases de datos 1 05-11-2004 17:57:13


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


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