события уровня базы данных (запуск и остановка базы данных, возникновение системных ошибок и т. п.).
Для реализации серверной бизнес-логики и динамических ограничений целостности обычно используются триггеры, срабатывающие на выполнение предложений INSERT, UPDATE, DELETE. Триггеры для остальных двух видов событий, как правило, используются администраторами баз данных для решения задач администрирования.
Триггеры на выполнение DML -предложений
Каждый триггер на выполнение предложений INSERT, UPDATE, DELETE «навешивается» на одну конкретную таблицу и имеет три основные настройки:
набор предложений SQL INSERT, UPDATE, DELETE, при выполнении которых будет срабатывать триггер;
тип срабатывания – до (BEFORE) или после (AFTER) внесения изменений в данные в ходе выполнения предложения SQL, вызвавшего срабатывание триггера;
сколько раз триггер будет срабатывать – один раз или по числу обработанных предложением SQL строк.
Рассмотрим эти настройки подробнее.
Для одного триггера можно указать любую непустую комбинацию из трех предложений INSERT, DELETE, UPDATE (всего получается 2 3-1=7 комбинаций). Если эта комбинация включает предложение UPDATE, то могут быть указаны конкретные столбцы таблицы, значения которых должны изменяться предложениями UPDATE, чтобы вызвать срабатывание триггера.
По количеству срабатываний триггеры делятся на два вида:
триггеры уровня предложения (statement-level triggers) – срабатывают один раз при выполнении вызвавшего срабатывание предложения SQL;
триггеры уровня строки (row-level triggers) – срабатывают на каждой строке, обрабатываемой вызвавшим срабатывание триггера предложением SQL.
Триггер уровня предложения при выполнении в базе данных предложения SQL, на которое он настроен, срабатывает всегда и срабатывает ровно один раз. А вот триггер уровня строки может не сработать ни разу, если предложение SQL не обработало ни одной строки. Если же предложение SQL обработало три строки, то триггер уровня строки сработает три раза, обработка десяти строк вызовет десять срабатываний такого триггера и так далее.
Условие срабатывания триггера уровня строки может быть уточнено дополнительным логическим условием в конструкции WHEN команды CREATE TRIGGER.
Команда создания триггера на выполнение DML-предложений имеет следующий синтаксис:
CREATE [OR REPLACE] TRIGGER имя_триггера
{BEFORE | AFTER} – тип срабатывания
{ INSERT | DELETE | UPDATE | UPDATE OF список столбцов } ON имя таблицы
[FOR EACH ROW] – триггер уровня строки
[WHEN (…)] – дополнительное логическое условие срабатывания
остальные разделы блока PL/SQL (объявлений,исполняемый,обработки исключений)
END;
В коде триггеров можно использовать специфичные средства:
операционные директивы INSERTING, UPDATING, DELETING;
псевдозаписи :NEW и :OLD (только для триггеров уровня строки).
Операционные директивы
Операционные директивы INSERTING, UPDATING, DELETING предназначены для идентификации предложения SQL, вызвавшего срабатывание триггера. Так как при создании триггера может указываться любая непустая комбинация из трех предложений INSERT, UPDATE, DELETE, то с помощью операционных директив INSERTING, UPDATING, DELETING внутри блока PL/SQL можно реализовать отдельные ветви потока команд для каждого из этих предложений.
Пусть, например, триггер срабатывает на INSERT и на DELETE, тогда исполняемый раздел блока триггера может быть построен следующим образом:
CASE
WHEN INSERTING THEN
логика обработки при срабатывании на INSERT
WHEN DELETING THEN
логика обработки при срабатывании на DELETE
END CASE;
Псевдозаписи :NEW и :OLD
Интуитивно ясно, что внутри триггеров уровня строки должна быть возможность обращаться к значениям столбцов строк, на которых срабатывают триггеры этого вида.
При каждом запуске триггера уровня строки виртуальная машина PL/SQL создает и заполняет две структуры данных – псевдозаписи :NEW и :OLD. Их структура идентична структуре записи PL/SQL, объявленной с помощью атрибута %ROWTYPE, то есть псевдозапись имеет все атрибуты с такими же именами и типами данных, какие есть столбцы у таблицы, на которую «навешен» триггер. В атрибутах псевдозаписи :OLD находятся исходные значения столбцов строки, на которой сработал триггер, а в атрибутах псевдозаписи :NEW – новые значения столбцов.
Перечислим понятные ограничения, касающиеся этих псевдозаписей:
у триггеров для INSERT нет данных в атрибутах :OLD;
у триггеров для DELETE нет данных в атрибутах :NEW и изменять их нельзя;
значения атрибутов :OLD изменять нельзя;
Читать дальше