Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Ответы на СУБД.docx
Скачиваний:
6
Добавлен:
30.08.2019
Размер:
146.57 Кб
Скачать

Типы хранимых процедур

Существуют несколько типов хранимых процедур.

  • Системные хранимые процедуры предназначены для выполнения различных административных действий.

Устно. Можно сказать, что системные хранимые процедуры являются интерфейсом, обеспечивающим работу с системными таблицами, которая, в конечном счете, сводится к изменению, добавлению, удалению и выборке данных из системных таблиц как пользовательских, так и системных баз данных. Системные хранимые процедуры имеют префикс sp_, хранятся в системной базе данных и могут быть вызваны в контексте любой другой базы данных.

  • Пользовательские хранимые процедуры реализуют действия пользователя. Каждая хранимая процедура располагается в конкретной БД, где и выполняется.

  • Временные хранимые процедуры существуют определенное время в зависимости от типа процедуры. Локальные временные хранимые процедуры могут быть вызваны только из того соединения, в котором созданы. При создании такой процедуры ей необходимо дать имя, начинающееся с одного символа #. Хранимые процедуры этого типа автоматически удаляются при отключении пользователя, перезапуске или остановке сервера. Глобальные временные хранимые процедуры доступны для любых соединений сервера, на котором имеется такая же процедура. Для ее определения необходимо, чтобы имя начиналось с символов ##. Удаляются эти процедуры при перезапуске или остановке сервера, а также при закрытии соединения, в контексте которого они были созданы.

7. Табличные переменные

Основное использование типа table – временное хранилище для набора строк, которые возвращаются как результирующий набор табличнозначной функции.

Объявление

При объявлении переменной переменная table инициализируется как пустая таблица. Если выполняется оператор SELECT сразу после объявления табличной переменной, то результатом будет пустой набор строк.

Не допускается присвоение одной табличной переменной другой.

Не допускается создание индексов на табличных переменных за исключением индексов, которые создаются ограничениями PRIMARY KEY и UNIQUE.

Функции пользователя

Функция пользователя (UDF) представляет собой модуль Transact-SQL, который принимает один или более входных аргументов и рассчитывает возвращаемое значение.

UDF может содержать как операторы управления ходом выполнения программы, так и операторы DML.

Определение функции пользователя

Прежде чем создать UDF инструкцией CREATE FUNCTION, необходимо определить следующие характеристики:

  • имя UDF,

  • схема (квалификатор),

  • число и типы данных входных параметров,

  • типы возвращаемых значений.

Для изменения функции используется инструкция ALTER FUNCTION, для удаления – DROP FUNCTION.

Нельзя использовать оператор ALTER FUNCTION для преобразования типов функций.

Типы операторов, которые могут использоваться в функции:

  • Оператор DECLARE.

  • Присвоение значений объектам, локальным относительно функции, с помощью опции SET или SELECT.

  • Операторы управления (например, IF..ELSE, WHILE, RETURN, GOTO, BREAK и CONTINUE).

  • Оператор SELECT, содержащий список выбора с выражениями, которые присваивают значения локальным переменным функции.

  • Операторы UPDATE, INSERT и DELETE.

  • Операторы EXECUTE, для вызова хранимых процедур.

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