Триггеры являются одной из разновидностей
хранимых процедур. Их исполнение происходит при выполнении для таблицы
какого-либо оператора языка манипулирования данными (DML). Триггеры
используются для проверки целостности данных, а также для отката транзакций.
Триггер – это откомпилированная SQL-процедура,
исполнение которой обусловлено наступлением определенных событий внутри реляционной
базы данных. Применение триггеров большей частью весьма удобно для
пользователей базы данных. И все же их использование часто связано с
дополнительными затратами ресурсов на операции ввода/вывода. В том случае,
когда тех же результатов (с гораздо меньшими непроизводительными затратами
ресурсов) можно добиться с помощью хранимых процедур или прикладных программ,
применение триггеров нецелесообразно.
Триггеры – особый инструмент SQL-сервера,
используемый для поддержания целостности данных в базе данных. С помощью
ограничений целостности, правил и значений по умолчанию не всегда можно
добиться нужного уровня функциональности. Часто требуется реализовать сложные
алгоритмы проверки данных, гарантирующие их достоверность и реальность. Кроме
того, иногда необходимо отслеживать изменения значений таблицы, чтобы нужным
образом изменить связанные данные. Триггеры можно рассматривать как своего рода
фильтры, вступающие в действие после выполнения всех операций в соответствии с
правилами, стандартными значениями и т.д.
Триггер представляет собой специальный тип
хранимых процедур, запускаемых сервером автоматически при попытке изменения
данных в таблицах, с которыми триггеры связаны. Каждый триггер привязывается к
конкретной таблице. Все производимые им модификации данных рассматриваются как
одна транзакция. В случае обнаружения ошибки или нарушения целостности данных
происходит откат этой транзакции. Тем самым внесение изменений запрещается.
Отменяются также все изменения, уже сделанные триггером.
Создает триггер только владелец базы данных.
Это ограничение позволяет избежать случайного изменения структуры таблиц,
способов связи с ними других объектов и т.п.
Триггер представляет собой весьма полезное и в
то же время опасное средство. Так, при неправильной логике его работы можно
легко уничтожить целую базу данных, поэтому триггеры необходимо очень тщательно
отлаживать.
В отличие от обычной подпрограммы, триггер
выполняется неявно в каждом случае возникновения триггерного события, к тому же
он не имеет аргументов. Приведение его в действие иногда называют запуском
триггера. С помощью триггеров достигаются следующие цели:
проверка корректности введенных данных и
выполнение сложных ограничений целостности данных, которые трудно, если вообще
возможно, поддерживать с помощью ограничений целостности, установленных для
таблицы;
выдача предупреждений, напоминающих о
необходимости выполнения некоторых действий при обновлении таблицы,
реализованном определенным образом;
накопление аудиторской информации посредством
фиксации сведений о внесенных изменениях и тех лицах, которые их выполнили;
поддержка репликации.
При условии правильного использования триггеры
могут стать очень мощным механизмом. Основное их преимущество заключается в
том, что стандартные функции сохраняются внутри базы данных и согласованно
активизируются при каждом ее обновлении. Это может существенно упростить
приложения. Тем не менее следует упомянуть и о присущих триггеру недостатках:
сложность: при перемещении некоторых функций в
базу данных усложняются задачи ее проектирования, реализации и
администрирования;
скрытая функциональность: перенос части функций
в базу данных и сохранение их в виде одного или нескольких триггеров иногда
приводит к сокрытию от пользователя некоторых функциональных возможностей. Хотя
это в определенной степени упрощает его работу, но, к сожалению, может стать
причиной незапланированных, потенциально нежелательных и вредных побочных
эффектов, поскольку в этом случае пользователь не в состоянии контролировать
все процессы, происходящие в базе данных;
влияние на производительность: перед
выполнением каждой команды по изменению состояния базы данных СУБД должна
проверить триггерное условие с целью выяснения необходимости запуска триггера
для этой команды. Выполнение подобных вычислений сказывается на общей
производительности СУБД, а в моменты пиковой нагрузки ее снижение может стать
особенно заметным. Очевидно, что при возрастании количества триггеров
увеличиваются и накладные расходы, связанные с такими операциями.
Неправильно написанные триггеры могут привести
к серьезным проблемам, таким, например, как появление "мертвых"
блокировок. Триггеры способны длительное время блокировать множество ресурсов,
поэтому следует обратить особое внимание на сведение к минимуму конфликтов доступа.
Комментариев нет:
Отправить комментарий
Дорогие друзья!
Если наш блог оказался для Вас интересным поделитесь им со своими друзьями в любимых социальных сетях.