Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » Oracle »

Problema al Crear un Trigger

Estas en el tema de Problema al Crear un Trigger en el foro de Oracle en Foros del Web. Hola Buenas tardes a todos! Quisiera ver si puedes ayudarme con lo siguiente: Tengo mi base de datos Oracle una tabla llamada Alumnos, donde tiene ...
  #1 (permalink)  
Antiguo 21/09/2012, 15:56
 
Fecha de Ingreso: septiembre-2008
Mensajes: 5
Antigüedad: 16 años, 3 meses
Puntos: 0
Exclamación Problema al Crear un Trigger

Hola Buenas tardes a todos!

Quisiera ver si puedes ayudarme con lo siguiente:

Tengo mi base de datos Oracle una tabla llamada Alumnos, donde tiene 9 campos pero quisiera que solo la encargada llene 7 registros mediante un formulario(pero ese no es el problema) de las cuales esos 2 campos restantes quiero llenarlos con un trigger; les explico acá esta mi tabla:

CREATE TABLE ALUMNOS
(
ID_ALUMNO CHAR(3) PRIMARY KEY,
NOMBRE VARCHAR2(50) NOT NULL,
APELLIDO VARCHAR2(50) NOT NULL,
SEXO VARCHAR2(1) NOT NULL,
F_NAC DATE NOT NULL,
PAGO NUMBER NOT NULL,
CANT_CUR_DES NUMBER NOT NULL,
USUARIO VARCHAR2(30),
FECHA DATE
)

pues esos 2 últimos campos, que es usuario y fecha, se debiera llenar al registrar un nuevo registro mediante un trigger, la cual he intentado de varias formas y no me sale y me gustaría bastante que me ayuden por favor, ya que tengo solo hasta el domingo, para solucionarlo.

CREATE OR REPLACE TRIGGER TR_NAME
AFTER INSERT ON ALUMNOS
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
BEGIN
UPDATE ALUMNOS
SET ID_ALUMNO=:OLD.ID_ALUMNO,
NOMBRE=:OLD.NOMBRE,
APELLIDO=:OLD.APELLIDO,
SEXO=:OLD.SEXO,
F_NAC=:OLD.F_NAC,
PAGO=:OLD.PAGO,
CANT_CUR_DES=:OLD.CANT_CUR_DES,
:NEW.USUARIO=USER,
:NEW.FECHA=SYSDATE;
END;

la cual al insertar debiera, activarse ese trigger para aumentar esos 2 últimos datos, y así sabre, quien lo registro y la fecha y hora en que lo hizo!

INSERT INTO ALUMNOS VALUES ('A01','JUNIOR','CÉSPEDES','M','22-08-1987','180','1','','');
  #2 (permalink)  
Antiguo 21/09/2012, 17:22
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Problema al Crear un Trigger

Cita:
pues esos 2 últimos campos, que es usuario y fecha, se debiera llenar al registrar un nuevo registro mediante un trigger
La verdad es que para llenar esos datos ni siquiera necesitas un TRIGGER. Normalmente se hace en el mismo INSERT, cuando se lo crea...

Hacerlo en un TRIGGER no le aporta absolutamente ninguna ventaja, y le agrega una complicación innecesaria al sistema.
Los trigger se deben usar únicamente cuando es estrictamente necesario por necesidades del sistema, y cuando el procesos a realizar no se puede solventar de ninguna otra forma.
Ten en cuenta que es algo que se ejecutará siempre.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)
  #3 (permalink)  
Antiguo 23/09/2012, 05:25
 
Fecha de Ingreso: junio-2007
Mensajes: 891
Antigüedad: 17 años, 6 meses
Puntos: 43
Respuesta: Problema al Crear un Trigger

No debes complicarte la vida con un update innecesario.

Esto te lo soluciona :

CREATE OR REPLACE TRIGGER TR_NAME
AFTER INSERT ON ALUMNOS
REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
BEGIN
:NEW.USUARIO=USER,
:NEW.FECHA=SYSDATE;
END;

Por otra parte, te recomendaría que en usuario no metas el de BBDD, sino el de red. A no ser que useis como usuarios de aplicacion uno de BBDD por cada usuario que maneja la aplicación.

gnzsoloyo : Los triggers de auditoria en los que se informa quien ha insertado , actualizado o borrado un registro son muy importantes y esos datos ( USUARIO y FECHA ) deben de rellenarse automaticamente, no mediante el insert-update y "delete" correspondiente.

Una buena operativa es que cada vez que se crea una tabla, se cree el correspondiente trigger de auditoria.
  #4 (permalink)  
Antiguo 23/09/2012, 08:45
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.324
Antigüedad: 17 años
Puntos: 2658
Respuesta: Problema al Crear un Trigger

Cita:
gnzsoloyo : Los triggers de auditoria en los que se informa quien ha insertado , actualizado o borrado un registro son muy importantes y esos datos ( USUARIO y FECHA ) deben de rellenarse automaticamente, no mediante el insert-update y "delete" correspondiente.
Mi estimado: Eso lo se de sobra, pero no era a donde apuntaba la pregunta de sharton...

Por otro lado, insisto que crear un trigger para algo que puede hacer en el mismo insert es completamente innecesario.

Respecto a las auditoirías, lo que propones de usar el usuario de servidor y no el de base puede no resultar una buena práctica porque eso te dice quién es el responsable último, pero no quien hace la operación, si en el sistema un usuario puede trabajar "a nombre de otro", como por ejemplo en el caso de usuario de ventas que posee vendedores subalternos, ninguno de los cuales se registra separadamente. En ese caso, tomar el usuario del servidor, no es una buena idea
No es un caso "excepcional", sino una práctica habitual en ciertos sistemas complejos con muchas restricciones para crear usuarios.
Precisamente yo trabajo en un sistema de esas características, que tiene alcance nacional. En el caso de la empresa para la que trabajo, una de las directivas del manual de buenas prácticas que posee el área de desarrollo de BBDD dice expresamente que no se deben crear triggers para tareas de auditoría, porque exigen demasiados accesos a disco, quitando performance. Toda la auditoría se realiza por operaciones asincrónicas, y los asientos de las tablas tienen que ir con el user del sistema (no el del servidor) y fecha de la modificación, que es lo que yo planteaba.

Como ves, la auditoría por triggers no es una regla absoluta.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)
  #5 (permalink)  
Antiguo 24/09/2012, 04:21
 
Fecha de Ingreso: junio-2007
Mensajes: 891
Antigüedad: 17 años, 6 meses
Puntos: 43
Respuesta: Problema al Crear un Trigger

No compañero, como bien dices reglas absolutas no hay, y menos en este mundillo.

Vosotros trabajais de una manera y nosotros de otra, ambas dos igual de buenas puesto que responden a nuestras necesidades. Vuestro manual de buenas prácticas dice no a los triggers de auditoría, en cambio el nuestro dice todo lo contrario.

Etiquetas: oracle10g, trigger
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 02:43.