Oracle/SQL/Triggers

< Oracle‎ | SQL

Son procedimientos de PL/SQL que se ejecutan automáticamente cuando se produce un evento determinado.

CREATE OR REPLACE TRIGGER nombre
{BEFORE | AFTER | INSTEAD OF} {INSERT | UPDATE | DELETE} [of columna, ...] ON tabla
[FOR EACH ROW]
[WHEN (condiciones)]
[declare
  -- Declaraciones del Trigger
  ...
]
begin
  -- Código del Trigger
  ...
end;

NOTA: Las {} encierran elementos alternativos, no son parte de la sintaxis.

Momento de Ejecución

editar
  • BEFORE: Antes del evento
  • AFTER: Después del evento
  • INSTEAD OF: Para vistas

Eventos de DML

editar
  • INSERT
  • UPDATE
  • DELETE

Cantidad de Ejecuciones

editar
  • FOR EACH ROW: Se ejecuta una vez por cada registro afectado
  • Sin modificador: Se ejecuta una vez por operación

Registros :old y :new

editar

Estos registros contienen los valores anteriores y posteriores a la operación.

En triggers tipo BEFORE, se puede modificar los valores de :new.

Filtro de registros

editar

WHEN (condición)

Se puede especificar campos de los registros old y new (en este caso sin el : inicial).

Deshabilitar y habilitar Triggers

editar
ALTER TRIGGER <nombre_trigger> DISABLE;
ALTER TRIGGER <nombre_trigger> ENABLE;

Error por Tabla mutante

editar

Cuando se consulta en un trigger de tipo FOR EACH ROW una tabla que está siendo afectada por la operación que disparó el trigger, se produce el error:

ORA-04091: table <owner>.<nombre_tabla> is mutating, trigger/function may not see it