115 - Disparadores (habilitar y deshabilitar)


Primer problema:

Una librería almacena los datos de sus libros en una tabla denominada "libros" y controla las acciones que los empleados realizan sobre dicha tabla almacenando en la tabla "control" el nombre del usuario, la fecha, y el tipo de modificación que se realizó sobre la tabla "libros".

1- Elimine la tabla "libros" y la tabla "control":

 drop table libros;
 drop table control;

2- Cree las tablas con las siguientes estructuras:

 create table libros(
  codigo number(6),
  titulo varchar2(40),
  autor varchar2(30),
  editorial varchar2(20),
  precio number(6,2)
 );

 create table control(
  usuario varchar2(30),
  fecha date,
  operacion varchar2(20)
 );

3- Ingrese algunos registros en "libros":

 insert into libros values(100,'Uno','Richard Bach','Planeta',25);
 insert into libros values(103,'El aleph','Borges','Emece',28);
 insert into libros values(105,'Matematica estas ahi','Paenza','Nuevo siglo',12);
 insert into libros values(120,'Aprenda PHP','Molina Mario','Nuevo siglo',55);
 insert into libros values(145,'Alicia en el pais de las maravillas','Carroll','Planeta',35);

4- Cree un disparador que se active cuando modificamos algún campo de "libros" y almacene en "control" el nombre del usuario que realiza la actualización, la fecha y en "operacion" coloque el nombre del campo actualizado

5- Cree otro desencadenador que se active cuando ingresamos un nuevo registro en "libros", debe almacenar en "control" el nombre del usuario que realiza el ingreso, la fecha e "insercion" en "operacion"

6- Cree un tercer trigger sobre "libros" que se active cuando eliminamos un registro de "libros", debe almacenar en "control" el nombre del usuario que realiza la eliminación, la fecha y "borrado" en "operacion"

7- Los tres triggers están habilitados. Consultamos el diccionario "user_triggers" para corroborarlo

8- Ingrese un libro y compruebe que el trigger "tr_ingresar_libros" se dispara recuperando los registros de "control"

9- Deshabilite el trigger "tr_ingresar_libros"

10- Consulte el diccionario "user_triggers" para corroborarlo
El trigger "tr_ingresar_libros" está deshabilitado, "tr_actualizar_libros" y "tr_eliminar_libros" están habilitados.

11- Ingrese un libro y compruebe que el trigger de inserción no se dispara recuperando los registros de "control":

 insert into libros values(152,'El anillo del hechicero','Gaskin','Planeta',22);
 select *from control;

12- Actualice la editorial de varios libros y compruebe que el trigger de actualización se dispara recuperando los registros de "control"

13- Deshabilite el trigger "tr_actualizar_libros"

14- Consulte el diccionario "user_triggers" para corroborarlo
Los triggers "tr_ingresar_libros" y "tr_actualizar_libros" están deshabilitados, "tr_eliminar_libros" está habilitado.

15- Borre un libro de "libros" y compruebe que el trigger de borrado se disparó recuperando los registros de "control"

16- Deshabilite el trigger "tr_eliminar_libros"

17- Consulte el diccionario "user_triggers" para comprobarlo
Los tres trigger establecidos sobre "empleados" están deshabilitados.

18- Elimine un libro de "libros" y compruebe que tal registro se eliminó de "libros" pero que el trigger de borrado no se dispara recuperando los registros de "control"

19- Habilite el trigger "tr_actualizar_libros"

20- Actualice el autor de un libro y compruebe que el trigger de actualización se dispara recuperando los registros de "control"

21- Habilite todos los triggers establecidos sobre "libros"

22- Consulte el diccionario "user_triggers" para comprobar que el estado (status) de todos los triggers establecidos sobre "libros" es habilitado
Los tres trigger establecidos sobre "libros" han sido habilitados. Se activarán ante cualquier sentencia "insert", "update" y "delete".

Ver solución

 drop table libros;
 drop table control;

 create table libros(
  codigo number(6),
  titulo varchar2(40),
  autor varchar2(30),
  editorial varchar2(20),
  precio number(6,2)
 );

 create table control(
  usuario varchar2(30),
  fecha date,
  operacion varchar2(20)
 );

 insert into libros values(100,'Uno','Richard Bach','Planeta',25);
 insert into libros values(103,'El aleph','Borges','Emece',28);
 insert into libros values(105,'Matematica estas ahi','Paenza','Nuevo siglo',12);
 insert into libros values(120,'Aprenda PHP','Molina Mario','Nuevo siglo',55);
 insert into libros values(145,'Alicia en el pais de las maravillas','Carroll','Planeta',35);

 create or replace trigger tr_actualizar_libros
  before update
  on libros
  for each row
 begin
  if updating('codigo') then
   insert into control values(user,sysdate,'codigo');
  end if;
  if updating('titulo') then
   insert into control values(user,sysdate,'titulo');
  end if;
  if updating('autor') then
   insert into control values(user,sysdate,'autor');
  end if;
  if updating('editorial') then
   insert into control values(user,sysdate,'editorial');
  end if;
  if updating('precio') then
   insert into control values(user,sysdate,'precio');
  end if;
 end tr_actualizar_libros;
 /

 create or replace trigger tr_ingresar_libros
  before insert
  on libros
  for each row
 begin
   insert into control values(user,sysdate,'insercion');
 end tr_ingresar_libros;
 /

 create or replace trigger tr_eliminar_libros
  before delete
  on libros
  for each row
 begin
   insert into control values(user,sysdate,'borrado');
 end tr_eliminar_libros;
 /

 select trigger_name, triggering_event, status
  from user_triggers
  where table_name = 'LIBROS';

 insert into libros values(150,'El experto en laberintos','Gaskin','Planeta',38);
 select *from control;

 alter trigger tr_ingresar_libros disable;

 select trigger_name, status
  from user_triggers
  where table_name = 'LIBROS';

 insert into libros values(152,'El anillo del hechicero','Gaskin','Planeta',22);
 select *from control;

 update libros set editorial='Sudamericana' where editorial='Planeta';
 select *from control;

 alter trigger tr_actualizar_libros disable;

 select trigger_name, status
  from user_triggers
  where table_name ='LIBROS';

 delete from libros where codigo=152;
 select *from control;

 alter  trigger tr_eliminar_libros disable;

 select trigger_name, status
  from user_triggers
  where table_name = 'EMPLEADOS';

 delete from libros where codigo=150;
 select *from libros where codigo=150;
 select *from control;

 alter trigger tr_actualizar_libros enable;

 update libros set autor='Adrian Paenza' where autor='Paenza';
 select *from control;

 alter table libros enable all triggers;

 select trigger_name, triggering_event, status
  from user_triggers
  where table_name = 'LIBROS';

 


Retornar