- •12. Создание таблиц посредством create table. Определение ограничений целостности not null, defoult, check, primary key, foreign key.
- •13. Выборка данных с помощью оператора select. Использование агрегатных функций в операторе select.
- •14. Оператор объединения union. Оператор пересечения intersect. Оператор вычитания exept.
- •15. Подзапросы. Классификация подзапросов. Реализация операций вычитания и пересечения посредством подзапросов.
- •16. Операторы модификации данных insert, update, delete.
- •17. Изменение структуры таблицы с помощью alter table.
- •18. Создание и использование представлений в субд ms sql Server.
- •19. Создание и выполнение хранимых процедур в субд ms sql Server
- •20. Создание и выполнение функций в субд ms sql Server
- •Функции Scalar
- •Функции Inline
- •Функции Multi-statement
- •21. Создание и использование триггеров ms sql Server. Триггеры типа instead of и типа after
- •Реализация триггеров в среде ms sql Server
- •Типы триггеров
- •Программирование триггера
- •22. Создание и использование курсоров в субд ms sql Server.
- •Управление курсором в среде ms sql Server
- •Объявление курсора
- •Открытие курсора
- •Выборка данных из курсора
- •Изменение и удаление данных
- •Закрытие курсора
- •Освобождение курсора
- •23. Проектирование баз данных с помощью метода нормальных форм. Определения нормальных форм. Понятия функциональной и транзитивной зависимостей.
- •Минимальные функциональные зависимости и вторая нормальная форма
- •Аномалии обновления, возникающие из-за наличия неминимальных функциональных зависимостей
- •Возможная декомпозиция
- •Вторая нормальная форма
- •Нетранзитивные функциональные зависимости и третья нормальная форма
- •Аномалии обновлений, возникающие из-за наличия транзитивных функциональных зависимостей
- •Возможная декомпозиция
- •Третья нормальная форма
- •Независимые проекции отношений. Теорема Риссанена
- •Ерекрывающиеся возможные ключи и нормальная форма Бойса-Кодда
- •Аномалии обновлений, связанные с наличием перекрывающихся возможных ключей
- •Нормальная форма Бойса-Кодда
- •Всегда ли следует стремиться к bcnf?
- •Заключение
- •24. Инфологическое проектирование. Основные этапы проэктирования бд с помощью метода «сущность-связь».
- •25. Даталогическое проектирование. Правила формирования отношений по er-диаграммам.
Открытие курсора
Для открытия курсора и наполнения его данными из указанного при создании курсора запроса SELECT используется следующая команда:
OPEN {{[GLOBAL]имя_курсора }
|@имя_переменной_курсора}
После открытия курсора происходит выполнение связанного с ним оператора SELECT, выходные данные которого сохраняются в многоуровневой памяти.
Выборка данных из курсора
Сразу после открытия курсора можно выбрать его содержимое (результат выполнения соответствующего запроса) посредством следующей команды:
FETCH [[NEXT | PRIOR | FIRST | LAST
| ABSOLUTE {номер_строки
| @переменная_номера_строки}
| RELATIVE {номер_строки |
@переменная_номера_строки}]
FROM ]{{[GLOBAL ]имя_курсора }|
@имя_переменной_курсора }
[INTO @имя_переменной [,...n]]
При указании FIRST будет возвращена самая первая строка полного результирующего набора курсора, которая становится текущей строкой.
При указании LAST возвращается самая последняя строка курсора. Она же становится текущей строкой.
При указании NEXT возвращается строка, находящаяся в полном результирующем наборе сразу же после текущей. Теперь она становится текущей. По умолчанию команда FETCH использует именно этот способ выборки строк.
Ключевое слово PRIOR возвращает строку, находящуюся перед текущей. Она и становится текущей.
Аргумент ABSOLUTE {номер_строки | @переменная_номера_строки} возвращает строку по ее абсолютному порядковому номеру в полном результирующем наборе курсора. Номер строки можно задать с помощью константы или как имя переменной, в которой хранится номер строки. Переменная должна иметь целочисленный тип данных. Указываются как положительные, так и отрицательные значения. При указании положительного значения строка отсчитывается от начала набора, отрицательного – от конца. Выбранная строка становится текущей. Если указано нулевое значение, строка не возвращается.
Аргумент RELATIVE {кол_строки | @переменная_кол_строки} возвращает строку, находящуюся через указанное количество строк после текущей. Если указать отрицательное значение числа строк, то будет возвращена строка, находящаяся за указанное количество строк перед текущей. При указании нулевого значения возвратится текущая строка. Возвращенная строка становится текущей.
Чтобы открыть глобальный курсор, перед его именем требуется указать ключевое слово GLOBAL. Имя курсора также может быть указано с помощью переменной.
В конструкции INTO @имя_переменной [,...n] задается список переменных, в которых будут сохранены соответствующие значения столбцов возвращаемой строки. Порядок указания переменных должен соответствовать порядку столбцов в курсоре, а тип данных переменной – типу данных в столбце курсора. Если конструкция INTO не указана, то поведение команды FETCH будет напоминать поведение команды SELECT – данные выводятся на экран.
Изменение и удаление данных
Для выполнения изменений с помощью курсора необходимо выполнить команду UPDATE в следующем формате:
UPDATE имя_таблицы SET {имя_столбца={
DEFAULT | NULL | выражение}}[,...n]
WHERE CURRENT OF {{[GLOBAL] имя_курсора}
|@имя_переменной_курсора}
За одну операцию могут быть изменены несколько столбцов текущей строки курсора, но все они должны принадлежать одной таблице.
Для удаления данных посредством курсора используется команда DELETE в следующем формате:
DELETE имя_таблицы
WHERE CURRENT OF {{[GLOBAL] имя_курсора}
|@имя_переменной_курсора}
В результате будет удалена строка, установленная текущей в курсоре.