Si solo se quiere desactivar un disparador o todos los de una sola tabla, ver el post «Activar/desactivar disparadores»
Para poder desactivar o activar todos los disparadores —triggers— de todas las tablas de un esquema determinado en Oracle, creamos el siguiente procedimiento que realizará la tarea. (distinto es, triggers de los cuales se es propietario)
Para poder desactivar o activar todos los disparadores —triggers— de todas las tablas de un esquema determinado en Oracle, creamos el siguiente procedimiento que realizará la tarea. (distinto es, triggers de los cuales se es propietario)
create or replace procedure ena_dis_all_tri
( p_opcion varchar2 default 'DISABLE'
, p_owner varchar2 default USER
)
/*
-- procedimiento que activa o desactiva todos los disparadores de todas las tablas del esquema especificado
-- recibe dos parametros opcionalmente:
-- p_opcion (enable, disable).
-- p_owner esquema/usuario al que le desactivamos/activamos los triggers de sus tablas.
-- valores por defecto de los parametros:
-- p_opcion=disable p_owner=user
-- Uso: ena_dis_all_tri[([p_opcion=>'p_opcion'][,p_usuario=>'p_usuario'])]
-- Ejemplos:
-- ena_dis_all_tri; --desactiva los triggers del usuario que ejecuta
-- ena_dis_all_tri(p_opcion=>'enable'); --activa los triggers del usuario que ejecuta
-- ena_dis_all_tri(p_usuario=>'hr'); --desactiva los triggers del usuario hr
-- ena_dis_all_tri(p_opcion=>'enable',p_usuario=>'hr'); --activa los triggers del usuario hr
*/
as
--variable auxiliar
v_aux number;
--cursor que nos dará el nombre de las tablas
--que hay que activar/desactivar todos los triggers
cursor cur is
select table_name
from all_triggers
where table_owner=upper(p_owner)
and status<>p_opcion||'D';
begin
into v_aux
from all_users
where username=upper(p_owner);
if v_aux=0 then
raise_application_error(-20000,'El usuario "'||p_owner||'" no existe.');
end if;
raise_application_error(-20001,'Opción "'||p_opcion||'" no válida. Usar: "ENABLE" o "DISABLE"');
end if;
execute immediate 'alter table '||p_owner||'.'||reg.table_name
||' '||p_opcion||' all triggers';
end loop;
end ena_dis_all_tri;
/
cursor cur is
select table_name
from all_triggers
where table_owner=upper(p_owner)
and status<>p_opcion||'D';
begin
--------------esta partes es opcional, solo sirve para realizar unas comprobaciones
--comprobamos de que no se ha introducido mal el nombre de usuario
select count(username)into v_aux
from all_users
where username=upper(p_owner);
if v_aux=0 then
raise_application_error(-20000,'El usuario "'||p_owner||'" no existe.');
end if;
--comprobamos de que no se ha introducido mal la opcion
if upper(p_opcion) not in ('ENABLE','DISABLE') thenraise_application_error(-20001,'Opción "'||p_opcion||'" no válida. Usar: "ENABLE" o "DISABLE"');
end if;
--------------fin parte opcional
--ejecutamos la tarea
for reg in cur loopexecute immediate 'alter table '||p_owner||'.'||reg.table_name
||' '||p_opcion||' all triggers';
end loop;
end ena_dis_all_tri;
/
Se ha realizado en una base de datos Oracle 10.2.0.1
El procedimiento se ejecutará con los permisos del usuario que cree el procedimiento. Debe tener privilegio CREATE ANY TRIGGER para poder visualizar los triggers en la vista ALL_TRIGGERS o tener acceso a las tablas. Además, permiso ALTER sobre las tablas y sobre los triggers, éste último porque pueden existir triggers asociados a las tablas del esquema creados por otro usuario.
El procedimiento se ejecutará con los permisos del usuario que cree el procedimiento. Debe tener privilegio CREATE ANY TRIGGER para poder visualizar los triggers en la vista ALL_TRIGGERS o tener acceso a las tablas. Además, permiso ALTER sobre las tablas y sobre los triggers, éste último porque pueden existir triggers asociados a las tablas del esquema creados por otro usuario.
grant alter any trigger,Comprobar la información con la siguiente SELECT:
alter any table,
create any trigger to usuario;
select owner,trigger_name,table_name,status
from all_triggers
where table_owner='USUARIO';
El uso del procedimiento queda bajo responsabilidad de quien lo utilice.
No hay comentarios:
Publicar un comentario