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

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

Лабораторная работа №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. Нарушение авторских прав; Мы поможем в написании вашей работы!




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


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

ФАКТОРЫ, ВЛИЯЮЩИЕ НА ИЗНОС ДЕТАЛЕЙ, И МЕТОДЫ СНИЖЕНИИ СКОРОСТИ ИЗНАШИВАНИЯ Кроме названных причин разрушений и износов, знание которых можно использовать в системе технического обслуживания и ремонта машин для повышения их долговечности, немаловажное значение имеют знания о причинах разрушения деталей в результате старения...

Различие эмпиризма и рационализма Родоначальником эмпиризма стал английский философ Ф. Бэкон. Основной тезис эмпиризма гласит: в разуме нет ничего такого...

Индекс гингивита (PMA) (Schour, Massler, 1948) Для оценки тяжести гингивита (а в последующем и ре­гистрации динамики процесса) используют папиллярно-маргинально-альвеолярный индекс (РМА)...

Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит...

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

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

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