Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
О.Б.Д / лекции / ЛЕКЦІЯ 11.ppt
Скачиваний:
32
Добавлен:
30.05.2020
Размер:
161.28 Кб
Скачать

Параметри синтаксису

RECOMPILE змушує систему створювати план виконання збереженої процедури при кожному її виклику;

FOR REPLICATION зазначається при реплікації даних і включенні створюваної збереженої процедури як стаття в публікацію;

ENCRYPTION наказує серверу виконати шифрування коду збереженої процедури;

AS розміщується на початку власне тіла збереженої процедури, тобто набору команд SQL, за допомогою яких і реалізовуватиметься та або інша дія;

Вихід зі збереженої процедури командою RETURN.

Виконання збереженої процедури

[[ EXEC [ UTE] і’мя_процедури [;номер]

[[@і’мя_параметра=]{значення | @і’мя_змінної} [OUTPUT]|[DEFAULT]] [,...n]

Параметри синтаксису

EXECUTE використовується, коли виклик збереженої процедури не є єдиною командою в пакеті;

Використовування OUTPUT дозволяється тільки для параметрів, які були оголошені при створенні процедури з ключовим словом OUTPUT

Процедура без параметрів. Розробити процедуру для отримання назв і вартості товарів, придбаних Івановим

CREATE PROC my_proc1 AS

SELECT Товар.Назва, Товар.Вартість*Операція.Кількість AS Вартість, Клієнт.Прізвище

FROM Клієнт INNER JOIN (Товар INNER JOIN Операція ON Товар.КодТовара=Операція.КодТовара)

ON Клієнт.КодКлієнта=Операція.КодКлієнта WHERE Клієнт.Прізвище=’Іванов’

Процедура без параметрів. Створити процедуру для зменшення ціни товару першого сорту на 10%.

CREATE PROC my_proc2 AS

UPDATE Товар SET Вартість = Вартість*0.9

WHERE Сорт = ’перший’

Процедура з вхідним параметром. Створити процедуру для отримання назв і вартості товарів, які придбав заданий

клієнт.

CREATE PROC my_proc3 @k VARCHAR(20) AS

SELECT Товар.Назва, Товар.Вартість*Операція.Кількість

AS Вартість, Клієнт.Прізвище

FROM Клієнт INNER JOIN (Товар INNER JOIN Операція ON Товар.КодТовара=Операція.КодТовара) ON Клієнт.КодКлієнта=Операція.КодКлієнта

WHERE Клієнт.Прізвище=@k

Для виклику процедури

EXEC my_proc3 'Іванов' або

my_proc3 @k='Іванов'

Процедура з вхідними параметрами. Створити процедуру для зменшення ціни товару заданого типу відповідно до вказаного %.

CREATE PROC my_proc4 @t VARCHAR(20) @p FLOAT

AS

UPDATE Товар SET Вартість=Вартість*(1-@p) WHERE Тип = @t

Для звернення до процедури

EXEC my_proc4 'Печиво', 0.05 або

EXEC my_proc4 @t = 'Печиво', @p = 0.05

Процедура з вхідними параметрами і значеннями за умовчанням. Створити процедуру для зменшення ціни товару заданого типу відповідно до вказаного %.

CREATE PROC my_proc5 @t VARCHAR(20)=’Цукерки’ @p FLOAT=0.1

AS UPDATE Товар SET Вартість=Вартість*(1-@p)

WHERE Тип=@t

Для звернення до процедури

EXEC my_proc5 'Печиво',0.05 або

EXEC my_proc5 @t='Печиво', @p=0.05 або

EXEC my_proc5 @p=0.05

EXEC my_proc5

Соседние файлы в папке лекции