![]() |
Главная Случайная страница Контакты | Мы поможем в написании вашей работы! | |
|
Триггеры - это хранимые процедуры, связанные с некоторыми событиями, происходящими во время работы базы данных. В качестве таких событий выступают операции вставки, обновления и удаления строк таблиц. Если в базе данных определен некоторый триггер, то он запускается автоматически всегда при возникновении события, с которым этот триггер связан. Очень важным является то, что пользователь не может обойти триггер. Триггер срабатывает независимо от того, кто из пользователей и каким способом инициировал событие, вызвавшее запуск триггера. Таким образом, основное назначение триггеров - автоматическая поддержка целостности базы данных. Триггеры могут быть как достаточно простыми, например, поддерживающими ссылочную целостность, так и довольно сложными, реализующими какие-либо сложные ограничения предметной области или сложные действия, которые должны произойти при наступлении некоторых событий. Например, с операцией вставки нового товара в накладную может быть связан триггер, который выполняет следующие действия - проверяет, есть ли необходимое количество товара, при наличии товара добавляет его в накладную и уменьшает данные о наличии товара на складе, при отсутствии товара формирует заказ на поставку недостающего товара и тут же посылает заказ по электронной почте поставщику.
По событию изменения триггеры различают на вызываемые при:
· Добавлении новой записи
· Изменении существующей записи
· Удалении записи
По отношению к событию, влекущему их вызов, триггеры различаются на:
· Выполняемые до наступления события
· Выполняемы после наступления события
Особенности триггеров:
· Непосредственно обратиться к триггеру нельзя
· Нельзя передавать параметры и получать значения выходных параметров
· Триггер всегда реализует действие
Преимущества использования триггеров:
· Автоматическое обеспечение каскадных воздействий, выполняющихся на сервере.
· Изменения в триггерах не влекут необходимости изменения клиентских приложений.
· Обязательное выполнение бизнес-правил, реализованных с использованием триггеров для всех приложений работающих с БД.
· Все изменения вносимые триггером выполняются в рамках одной транзакции. Как следствие, при откате транзакции откатываются также и все изменения, внесенные в БД триггерами.
Дата публикования: 2014-12-28; Прочитано: 367 | Нарушение авторского права страницы | Мы поможем в написании вашей работы!