Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Лабораторная работа №7





Создание триггеров

Триггер – эта та же хранимая процедура, но привязанная к событию изменения со­держимого конкретной таблицы.

Возможны три события, связанных с изменением содержимого таблицы, к которым можно привязать триггер:

insert – вставка новых данных в таблицу;

delete – удаление данных из таблицы;

Update – обновление данных в таблице.

MS

Создадим триггер, который выполняется проверку при вставке новых данных в таблицу Клиент: если № Клиента задаётся равным 0, то вставка не выполняется, выводится сообщение: «Нельзя ввести такое число» и происходит откат назад:

CREATE TRIGGER proverka ON Klient FOR INSERT

AS

IF EXISTS (SELECT * FROM Klient WHERE [N klienta]='0')

BEGIN

PRINT 'Нельзя ввести такое число'

ROLLBACK TRANSACTION

END

GO

USE [Notarius]

GO

Второй триггер не даёт вставить в таблицу Сделка Дату, которая ещё не наступила:

CREATE TRIGGER DATE ON Sdelka FOR INSERT

AS

IF (SELECT Data FROM inserted) > GETDATE()

BEGIN PRINT 'Вы ввели неверную дату!'

ROLLBACK TRANSACTION;

END

GO

ORACLE

Данный триггер не позволит добавить в таблицу Услуга услугу дешевле 500:

CREATE TRIGGER stUsl

BEFORE INSERT ON Usluga

FOR each row

BEGIN

if(new.stoimost_uslugi<500)

then

raise_application_error(-20000, 'Слишком маленькая стоимость!');

end if;

END; /

Данный триггер не позволяет заносить сделки, которые произошло позже 30 декабря 2012 года:

CREATE TRIGGER tr2

BEFORE INSERT ON Sdelka

FOR each row

BEGIN

if(new.data_sdelki>30-DEC-12)

then

raise_application_error(-20000, 'Неверная дата');

end if;

END;

Лабораторная работа №8

Транзакции

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

Если на этапе выполнения одного из запросов происходит сбой, это может нарушить целостность БД (товар может быть продан, а число товарных позиций на складе не обновлено). Чтобы сохранить целостность БД, все изменения должны выполняться как единое целое. Либо все изменения успешно выполняются, либо, в случае сбоя, БД принимает состояние, которое было до начала изменений. Это обеспечивается средствами обработки транзакций.

Транзакция – последовательность операторов SQL, выполняющихся как единая операция, которая не прерывается другими клиентами.

MS

Пример транзакции:

DECLARE @First int, @Second int

BEGIN TRANSACTION

UPDATE Skidka

SET [Razmer skidki]=500

WHERE [N skidki]=5

SET @First=@@ERROR

SAVE TRANSACTION SS

UPDATE Skidka

SET [Vid skidki]='Pensioneram'

WHERE [N skidki]=5

SET @Second=@@ERROR

IF @Second<>0

ROLLBACK TRANSACTION SS

IF @First=0 AND @Second=0

BEGIN







Дата добавления: 2015-06-15; просмотров: 384. Нарушение авторских прав; Мы поможем в написании вашей работы!




Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...


Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...


ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...


Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...

Особенности массовой коммуникации Развитие средств связи и информации привело к возникновению явления массовой коммуникации...

Тема: Изучение приспособленности организмов к среде обитания Цель:выяснить механизм образования приспособлений к среде обитания и их относительный характер, сделать вывод о том, что приспособленность – результат действия естественного отбора...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

Кран машиниста усл. № 394 – назначение и устройство Кран машиниста условный номер 394 предназначен для управления тормозами поезда...

Приложение Г: Особенности заполнение справки формы ву-45   После выполнения полного опробования тормозов, а так же после сокращенного, если предварительно на станции было произведено полное опробование тормозов состава от стационарной установки с автоматической регистрацией параметров или без...

Измерение следующих дефектов: ползун, выщербина, неравномерный прокат, равномерный прокат, кольцевая выработка, откол обода колеса, тонкий гребень, протёртость средней части оси Величину проката определяют с помощью вертикального движка 2 сухаря 3 шаблона 1 по кругу катания...

Studopedia.info - Студопедия - 2014-2026 год . (0.01 сек.) русская версия | украинская версия