Главная | Обратная связь | Поможем написать вашу работу!
МегаЛекции

Задание на лабораторную работу




Выполнить примеры. Написать запрос на вставку в таблицу записей с новыми данными по предметной области (прил.). Написать запрос на удаление всех записей, по определенному параметру. Написать запрос на изменение названий, которые содержат сочетание букв ‘ка’.

Оформить отчет, содержащий цель, ход выполнения работы и выводы.

Контрольные вопросы

1. Что содержит аргумент column_list команды INSERT?

2. Для чего используется ключевое слово SET?

3. При помощи какой команды осуществляется изменение данных?

4. При помощи какой команды осуществляется удаление данных?


Лабораторная работа № 4.

ТИПЫ ФУНКЦИЙ И ХРАНИМЫЕ ПРОЦЕДУРЫ

Цель работы

- Закрепление теоретических знаний по функциям и хранимым процедурам.

- Приобретение практических навыков по работе с пользовательскими функциями и хранимыми процедурами.

- Создание отдельных функций и хранимых процедур для работы с БД предметной области.

 

Теоретическая часть

Общие сведения

Функции в языках программирования – это конструкции, содержащие часто исполняемый код. Функция выполняет какие-либо действия над данными и возвращает некоторое значение. Каждая функция обладает собственным именем, и когда это имя встречается в основной программе (обычно в выражениях или командах присваивания), управление передается данной функции. Этот процесс называется вызовом функции.

SQL Server поддерживает два типа функций:

- встроенные функции (built-in functions). Встроенные функции являются состав­ной частью среды программирования и выполняют заранее предопределенную последовательность команд Transact-SQL. Они не могут быть модифициро­ваны пользователем. К таким функциям относятся, например, LEN, POWER, SUSER_NAME и др.

- функции пользователя (user-defined functions). Имя таких функций и после­довательность входящих в HPIX команд задает сам пользователь. В предыду­щих версиях SQL Server, в том числе и в SQL Server 7.0, функции пользовате­ля как объект базы данных отсутствовали.

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

Классы функций пользователя:

- Scalar – эти функции характеризуются тем, что возвращают обычное скаляр­ное значение любого из типов данных, поддерживаемых SQL Server, за исключением типов данных timestamp (rowversion), text, ntext, image, table и cursor. Функция может включать множество команд, которые объединяются в один блок с помощью конструкции BEGIN...END.

- Inline – отличительной особенностью этой функции является то, что она содержит всего одну команду – запрос SELECT. С помощью этого запроса фор­мируется набор данных, который и возвращается пользователю в виде зна­чения типа данных table.

- Multi-statement – как и функции предыдущего типа, функции рассматривае­мого типа возвращают пользователю значение типа данных table, содержа­щее набор данных. Однако, в отличие от функций класса Inline, при работе с функциями класса Multi-statement тело функции может содержать множество команд Transact-SQL (таких, как INSERT, UPDATE и т.д.). Именно с помощью этих команд и формируется набор данных, который должен быть возвращен после выполнения функции.

Все рассмотренные классы функций могут содержать ни одного, один или более входных параметров одного из поддерживаемых SQL Server 2000 типов данных, за исключением типов timestamp (rowversion), cursor и table. В теле функций (за исключением функций класса Inline) разрешается объявление локальных пере­менных, использование циклов, ветвлений и любых других программных конструкций. Также разрешается вызов других функций и хранимых процедур и создание внутри функции курсоров.

При использовании команд INSERT, UPDATE и DELETE существует ограничение – с помощью этих команд разрешается работать только с наборами данных, хранящихся в переменных типа table и принадлежащих временным таблицам, созданным в теле функции. Помимо указанных ограничений при разработке функций следу­ет учитывать, что они не могут возвращать данные непосредственно клиенту, как это может делать хранимая процедура. То есть не разрешается использование в теле функции команды PRINT, а также команды SELECT для непосредственного воз­вращения данных.

 

Поделиться:





Читайте также:





Воспользуйтесь поиском по сайту:



©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...