Главная страница
Содержание
 
 

Триггеры в Оракл

 

Tриггер (TRIGGER) — это хранимая процедура, которая запускается (автоматически выполняется) тогда, когда происходит связанное с триггером событие. Обычно события связаны с выполнением операторов INSERT, UPDATE или DELETE в некоторой таблице. Наличие триггеров открывает практически неограниченные возможности по формированию проверок полномочий и допустимости действий, связанных с модификацией данных.

Событие, управляющее запуском триггера, описывается в виде логических условий. Когда возникает событие, соответствующее условиям триггера, сервер Oracle автоматически запускает триггер, то есть интерпретирует код программы триггера, записанный на языке PL/SQL.

Обычно триггеры используют для выполнения сложных проверок ограничений целостности, многоаспектных проверок выполнения правил разграничения доступа и т.п.

Триггер запускается при выполнении одной из трех операций изменения содержимого таблицы:  INSERT, DELETE или UPDATE. Триггер может запускаться и несколькими операторами, но хотя бы один оператор из тройки должен быть обязательно указан в условии запуска триггера. Если перечень операторов, запускающих триггер, включает оператор UPDATE, то для условий срабатывания могут быть указаны конкретные изменяемые столбцы.

Код триггера может выполняться либо до, либо после тех операторов, которые инициировали запуск триггера. Например, если триггер запускается перед выполнением операции модификации данных для проверки полномочий пользователя на право выполнения операции, то, конечно, нужно использовать триггер с запуском до выполнения операции (с ключевым словом BEFORE). Если триггер применяется для формирования данных для аудиторской записи, то разумно  использовать триггер с запуском после выполнения операции (с ключевым словом AFTER).

Код триггера может быть ассоциирован либо с операцией над таблицей в целом, либо с каждой строкой, над которой выполняется операция. В зависимости от этого триггеры подразделяют на операторные триггеры и строчные триггеры. Операторные триггеры обычно используют для проверки правил разграничения доступа, оперирующих таблицей в целом, а строчные триггеры часто используют для проверки ограничений целостности при вставке строк. Условие запуска строчного триггера может быть уточнено дополнительным логическим условием.

Чтобы создать триггер, необходимо иметь системные привилегии CREATE TRIGGER. Для создания триггера в схеме, отличной от текущей схемы пользователя, требуются системные привилегии CREATE ANY TRIGGER.

Оператор определения триггера Oracle использует следующий синтаксис:
CREATE [OR REPLACE] TRIGGER [имя_схемы.] имя_триггера {BEFORE | AFTER}
{INSERT | DELETE | UPDATE [OF имя_столбца [, имя_столбца…]] }
[OR {INSERT | DELETE | UPDATE [OF имя_столбца [, имя_столбца…]] }…] ON [имя_схемы.]{имя_таблицы | имя_представления}
[FOR EACH ROW] [WHEN условие]

Ключевое слово OR REPLACE указывает на безусловное замещение старого текста триггера. Если ключевое слово OR REPLACE не указано и триггер определен в системе, то замещения старого значения триггера не происходит, и возвращается сообщение об ошибке.

Ключевые слова BEFORE или AFTER указывают на выполнение кода триггера либо до, либо, соответственно, после операторов манипулирования данными, инициировавших запуск триггера.

Ключевые слова INSERT, DELETE или UPDATE определяют конкретный оператор, запускающий триггер. Для оператора UPDATE могут быть указаны столбцы, изменение которых запускает триггер. Если конкретные столбцы не указаны, то триггер запускает изменение любого столбца. Необязательное ключевое слово OR присоединяет дополнительный оператор, запускающий триггер.

Ключевое слово ON задает имя таблицы или представления, ассоциированного с триггером. Необязательное ключевое слово ON EACH ROW определяет триггер как строчный. Необязательное ключевое слово WHEN задает дополнительное логическое условие, сужающее область действия триггера.

Прежде чем перейти к примеру построения триггера, приведем некоторые дополнительные сведения об обработке исключительных ситуаций в Oracle. Для подключения к механизму обработки ошибок пользовательских точек входа применяется процедура RAISE_APPLICATION_ERROR. С ее помощью можно обработать до 1000 определяемых пользователем ошибок с номерами в диапазоне от -20000 до -20999.

Вызов процедуры RAISE_APPLICATION_ERROR приводит к генерации исключительной ситуации и завершению выполнения вызвавшей процедуру программы (сравните с рассмотренным выше оператором PL/SQL RAISE). При  этом в среду, вызвавшую программу, возвращается номер и текстовое сообщение о типе ошибки.

В отличие от процедур, функций и пакетов сервер Oracle не хранит код триггера в виде скомпилированного блока PL/SQL. При первом запуске триггера его код считывается из словаря данных, компилируется, и скомпилированная версия сохраняется в области SGA. Поэтому для часто используемых триггеров целесообразно код, отвечающий за процедурную часть триггера, включать в хранимую процедуру, а в теле триггера оставлять только запись условий запуска и вызовы соответствующих процедур и функций.

Пример к л.р. № 3:
Создадим триггер работающий при изменении количества товара в таблице Товар. При этом в таблице Склад меняется общее количество товара.

create or replace trigger trigger1 after update of Kol on Tovar for each row  
begin
update Sklad set Kol=kol-:old.kol+:new.kol; --вычисляемые поля
where Kod_Group=:new.Kod_Group;
end trigger1;

На предложения языка SQL, включенные в код триггера Oracle, наложены следующие ограничения. Тело триггера не может включать в себя явное использование управляющих операторов COMMIT, ROLLBACK и SAVEPOINT, операторов языка определения данных CREATE, ALTER и DROP, операторов, управляющих разграничением доступа GRANT и REVOKE, а также неявное выполнение перечисленных операторов через вызовы процедур и функций.