- •Кафедра экономической информатики
- •Базы данных
- •Содержание
- •Введение
- •Лабораторная работа №1. Логические и физические модели данных
- •Методические указания
- •Задание к работе
- •Раздел I. Создание сущностей в eRwin
- •Раздел II. Создание связей между сущностями, подмножеств модели и хранимых отображений. Переход к физической модели данных
- •Раздел III. Выполнение операции прямого проектирования
- •Раздел IV. Выполнение операции обратного проектирования
- •Лабораторная работа №2. Усложненные диаграммы «сущность-связь»
- •Методические указания
- •Задание к работе
- •Раздел I. Создание сущностей логической модели
- •Раздел II. Создание связей между сущностями и иерархии наследования
- •Раздел III. Выполнение вариантов трансформы категориальной связи
- •Раздел IV. Выполнение методов синхронизации системного каталога базы данных и текущей модели
- •Лабораторная работа №3. Работа в среде субд «ms sql Server 2005»
- •Методические указания
- •Задание к работе
- •Раздел I. Создание базы данных и ее объектов
- •Раздел II. Управление пользователями и правами доступа к данным
- •Лабораторная работа №4. Создание базы данных и ее объектов с помощью команд языка Transact-sql
- •Методические указания и задания к выполнению
- •Раздел I. Создание базы данных и ее объектов
- •Раздел II. Ввод данных в таблицы базы данных
- •Insert into Заказ (КодКлиента, КодТовара, Количество)
- •Inner join Поставщик
- •Inner join Товар
- •Раздел III. Управление пользователями и правами доступа к данным.
- •Раздел IV. Анализ полученных результатов
- •Лабораторная работа №5. Манипулирование данными с помощью команд языка Transact-sql
- •Методические указания
- •Раздел I. Выборка данных из таблиц и представлений.
- •Раздел II. Обновление данных в таблицах и представлениях.
- •Раздел III. Удаление данных из таблиц и представлений.
- •Раздел IV. Изменение структуры таблицы.
- •Раздел V. Удаление таблицы из базы данных.
- •Задание к работе
- •Лабораторная работа №6. Программирование на языке Transact-sql
- •Методические указания
- •Раздел I. Основы программирования на языке Transact-sql.
- •Раздел II. Создание и работа с хранимыми (на сервере) процедурами.
- •If @Страна is not null
- •If @Город is not null
- •If @Город is not null
- •Insert into Валюта
- •Values(@Код, @Имя, @Шаг, @Курс)
- •If @Страна is not null
- •If @Город is not null
- •Into ##Регион
- •Раздел III. Создание и работа с определяемыми пользователем функциями.
- •Insert @rowset (КодРегиона, Страна, Область, Город)
- •Задание к работе
- •Лабораторная работа №7. Курсоры и триггеры в языке Transact-sql
- •Методические указания
- •Раздел I. Использование курсоров в языке Transact-sql
- •If @НачалоИнтервала is null
- •If @КонецИнтервала is null
- •Раздел II. Создание триггеров в языке Transact-sql.
- •If update(ДатаЗаказа)
- •If update(Цена)
- •If update(Цена)
- •Inserted.Цена * Валюта.КурсВалюты
- •Задание к работе
- •Литература Основная
- •Базы данных
- •220013, Минск, п. Бровки, 6.
If update(ДатаЗаказа)
BEGIN
PRINT 'Обновление столбца "ДатаЗаказа" запрещено'
ROLLBACK TRAN -- откат транзакции
END
GO
Примечание. Команда PRINT в отличие от команды SELECT выводит сообщения не на панель Results, а на панель Messages окна Query утилиты SQL Server Management Studio.
Теперь, не смотря на то, что вы являетесь владельцем базы данных, вы уже не можете редактировать значения столбца ДатаЗаказа в таблице Заказ:
SELECT * FROM Заказ -- команда 1
UPDATE Заказ -- команда 2
SET ДатаЗаказа = ДатаЗаказа + 10
GO -- команда 3
SELECT * FROM Заказ -- команда 4
Примечание. Все 4 команды, приведенные выше, выделите подсветкой в окне Query и выполните за один раз. Тогда будут показаны две таблицы Заказ (до и после корректировки).
Пример 2. Предварительно добавим в таблицу Заказ два новых столбца: Стоимость и СтоимостьНВ:
ALTER TABLE Заказ ADD Стоимость MONEY NULL
ALTER TABLE Заказ ADD СтоимостьНВ MONEY NULL
GO
Убедимся, что столбцы Стоимость и СтоимостьНВ (стоимость в национальной валюте) добавились в таблицу Заказ и во всех строках получили значение NULL:
SELECT * FROM Заказ
GO
Теперь создадим триггер для таблицы Товар, срабатывающий при любом изменении цены товара и корректирующий в таблице Заказ значения полей Стоимость и СтоимостьНВ в тех строках, которые соответствуют товару с изменившейся ценой:
CREATE TRIGGER tr_Товар_Цена
ON Товар
FOR UPDATE AS
If update(Цена)
BEGIN
-- объявляем локальные переменные
DECLARE @КодТовара INT, @Цена MONEY, @ЦенаНВ MONEY
-- присваиваем значения локальным переменным, выбирая эти
-- значения из таблицы inserted
SELECT @КодТовара = inserted.КодТовара,
@Цена = inserted.Цена, @ЦенаНВ = inserted.Цена *
Валюта.КурсВалюты
FROM inserted INNER JOIN Валюта
ON inserted.КодВалюты = Валюта.КодВалюты
-- обновляем значения стоимостей в таблице Заказ
UPDATE Заказ
SET Стоимость = Количество * @Цена,
СтоимостьНВ = Количество * @ЦенаНВ
WHERE КодТовара = @КодТовара
END
GO
Проверим работу созданного триггера. Для этого изменим цену товара с кодом 111:
SELECT * FROM Товар
UPDATE Товар
SET Цена = 50
WHERE КодТовара = 111
SELECT * FROM Товар
GO
Теперь посмотрим содержимое таблицы Заказ и убедимся, что подсчитались стоимости заказов, относящиеся к товарам с кодом 111:
SELECT * FROM Заказ
GO
Однако данный триггер обладает тем недостатком, что отслеживает изменение цены лишь одного товара, даже если были одновременно изменены цены сразу у нескольких товаров. Убедимся в этом, изменив цены сразу для всех товаров:
SELECT * FROM Товар
UPDATE Товар
SET Цена = Цена * 2
SELECT * FROM Товар
GO
Снова посмотрим содержимое таблицы Заказ и убедимся, что подсчитались стоимости заказов только по товару, представленному первой строкой таблицы Товар:
SELECT * FROM Заказ
SELECT * FROM Товар
GO
Устраним указанный выше недостаток путем внесения изменения в код триггера:
ALTER TRIGGER tr_Товар_Цена
ON Товар
FOR UPDATE AS