русс | укр

Языки программирования

ПаскальСиАссемблерJavaMatlabPhpHtmlJavaScriptCSSC#DelphiТурбо Пролог

Компьютерные сетиСистемное программное обеспечениеИнформационные технологииПрограммирование

Все о программировании


Linux Unix Алгоритмические языки Аналоговые и гибридные вычислительные устройства Архитектура микроконтроллеров Введение в разработку распределенных информационных систем Введение в численные методы Дискретная математика Информационное обслуживание пользователей Информация и моделирование в управлении производством Компьютерная графика Математическое и компьютерное моделирование Моделирование Нейрокомпьютеры Проектирование программ диагностики компьютерных систем и сетей Проектирование системных программ Системы счисления Теория статистики Теория оптимизации Уроки AutoCAD 3D Уроки базы данных Access Уроки Orcad Цифровые автоматы Шпаргалки по компьютеру Шпаргалки по программированию Экспертные системы Элементы теории информации

Триггеры INSERT


Дата добавления: 2015-08-14; просмотров: 657; Нарушение авторских прав


Триггеры

Триггер – это набор инструкций SQLServer, который выглядит и действует подобно хранимой процедуре, но триггер нельзя вызвать с помощью команды EXEC. Триггеры активизируются при выполнении пользователем определенной инструкции Transact-SQL. Существует два вида триггеров :

- DMLзапускаются с помощью инструкций INSERT, UPDATEили DELETE.

- DDLс помощью инструкций CREATE, ALTER, DROP.

Если вы не хотите, чтобы триггеру передавались записи, нужно добавить команду ROLLBACKв соответствующее место в коде. КомандаROLLBACK указывает серверу остановить обработку модификации и запретить транзакцию.

Существует также команда RAISEERROR с помощью которой вы можете отправить сообщение об ошибке пользователю.

 

Триггеры INSERT

Триггеры INSERTзапускаются при каждой попытке создать новую запись в таблице с помощью команды INSERT. При попытке вставить новую запись в таблицуSQLServerкопирует эту запись в таблицу триггеров БД и специальную таблицу inserted.

 

пример: допустим у нас есть таблица «Sotrydnik» БД “Ludi”. Необходимо запретить вставлять запись о сотруднике оклад которого, менее 20000 рублей.

 

1. Открыть SQL Server Management Studio. В окне Object Explorer развернутьпапкуБД «Ludi” - Programmability – Triggers.

2. Щелкаем правой кнопкой мыши на папке Triggersи выбираем команду NewTriggers.

3. В нашем случае триггер будет выглядеть следующим образом:

 

CREATE TRIGGER primer1

ON sotrydnik

AFTER INSERT

AS

BEGIN

SET NOCOUNT ON;

if (select oklad from inserted)<'20000'

rollback

print'Вы не можете вставлять запись о сотруднике с окладом менее 20 000 рублей'

END

GO4. Выполняем триггер, нажав на кнопку на панели инструментов. В результате в нижней части экрана мы увидим строчку «Command(s) completedsuccessfully».



5. Далее сохраняем триггер, щелкнув по кнопке Save

Чтобы протестировать новый триггер, необходимо создать запрос, нажав на кнопку New Query , следующего содержания

 

USE LUDI

INSERT SOTRYDNIK

VALUES (‘S28’,’Петров’,’Валерий’,’Михайлович’,’10000’,’2’,’1’)

Выполняем запрос, щелкнув по кнопке

, в нижней части окна увидим сообщение об ошибке, что такую запись вставлять нельзя.

 

Итак, мы создали триггер, который при вставке новой записи, проверяет вводимый оклад.

 



<== предыдущая лекция | следующая лекция ==>
Диодные детекторы | Триггеры DELETE


Карта сайта Карта сайта укр


Уроки php mysql Программирование

Онлайн система счисления Калькулятор онлайн обычный Инженерный калькулятор онлайн Замена русских букв на английские для вебмастеров Замена русских букв на английские

Аппаратное и программное обеспечение Графика и компьютерная сфера Интегрированная геоинформационная система Интернет Компьютер Комплектующие компьютера Лекции Методы и средства измерений неэлектрических величин Обслуживание компьютерных и периферийных устройств Операционные системы Параллельное программирование Проектирование электронных средств Периферийные устройства Полезные ресурсы для программистов Программы для программистов Статьи для программистов Cтруктура и организация данных


 


Не нашли то, что искали? Google вам в помощь!

 
 

© life-prog.ru При использовании материалов прямая ссылка на сайт обязательна.

Генерация страницы за: 0.117 сек.