Курсоры - раздел Программирование, Среда Delphi широко известна и не вызывает дополнительных трудностей при изучении и использовании
Когда Результатом Выполнения Запроса Sql В Программном Режиме...
Когда результатом выполнения запроса SQL в программном режиме является не одна строка, а целая таблица, необходимо обеспечить для прикладной программы возможность построчного получения результатов запроса. Для этого вводится понятие курсора. Рассмотрим вкратце механизм выполнения многострочного запроса и требуемые для этого новые операторы.
1. Оператор DECLARE CURSOR определяет выполняемый запрос с помощью оператора SELECT и связывает имя курсора с данным запросом.
2. Оператор OPEN инициирует выполнение запроса.
3. Оператор FETCH позволяет последовательно премещаться по строкам таблицы результатов, извлекая данные в базовые переменные.
4. Оператор CLOSE ликвидирует связь между курсором и таблицей результатов.
Оператор DECLARE CURSOR в большинстве СУБД не является выполняемым и должен располагаться в программе перед любыми операторами, работающими с данным курсором.
Обычно оператор FETCH продвигает курсор на следующую строку таблицы результатов. В стандарте SQL92 появилось понятие прокручиваемого курсора, задаваемого параметром SCROLL при его объявлении. Для прокручиваемого курсора в операторе FETCH задается один из параметров FIRST, LAST, NEXT, PRIOR, ABSOLUTE, RELATIVE, что позволяет извлечь соответственно первую строку результата, последнюю, следующую, предыдущую, с определенным номером, с определенным сдвигом по сравнению с текущей строкой. Прокручиваемые курсоры могут потребовать выполнения большого объема вычислений.
Курсоры могут быть обновляемыми, что задается фразой FOR UPDATE при объявлении курсора. Если одна строка результатов запроса строго соответствует определенной строке таблицы, то в процессе просмотра пользователь может обновить или удалить определенные строки курсора и внести соответствующие изменения в базовую таблицу. Например, оператор
DELETE FROM Anketa WHERE CURRENT OF Cursor_Ank
удалит текущую строку из курсора Cursor_Ank, а затем и соответствующую строку из таблицы Anketa. Использование обновляемых курсоров обычно связано с определенными ограничениями.
В настоящее время список источников по теории и практике использования баз... В данном пособии подробно излагаются вопросы связанные с проектированием и нормализацией базы данных реляционной...
Если Вам нужно дополнительный материал на эту тему, или Вы не нашли то, что искали, рекомендуем воспользоваться поиском по нашей базе работ:
Курсоры
Что будем делать с полученным материалом:
Если этот материал оказался полезным ля Вас, Вы можете сохранить его на свою страничку в социальных сетях:
История создания баз данных
Существуют различные определения базы данных. Обычно они либо неполны, либо слишком громоздки. Дадим простое определение, расширяя его по мере появления новых понятий.
Модели данных СУБД
Коцептуальной моделью данных в БД называют глобальное логическое описание данных. Структуры данных коцептуальной модели влияют на все характеристики СУБД, охватывая
· языки
Двенадцать правил Кодда для реляционных СУБД
В статье, опубликованной в 1985 году [3], Э. Кодд сформулировал двенадцать правил, которым должна соответствовать настоящая реляционная БД. Они являются полуофициальным определением понятия
Нормальная форма Бойса-Кодда
Пусть в определенном выше отношении SP присутствует еще и имя поставщика Sname. Будем для удобства считать, что имя однозначно определяет поставщика. Тогда в отношении SP (Sn, Sname
Четвертая нормальная форма
Рассмотрим таблицу R (Subj, Teach, Book), где Subj – учебный предмет, Teach- преподаватель по этому предмету, Book – книга, рекомендуемая преподавателем Teach для изучения предмета
Семантическое моделирование данных.
Элементы модели "сущность-связь"
Семантическое моделирование данных на основе ER-диаграмм компактно и доступно изложено в [5], и мы будем следовать этому источни
В реляционной СУБД
Одним из главных достоинств иерархических и сетевых СУБД считают естественность представления данных иерархической и сетевой природы. А как представлять такие данные в реляционных С
Основы реляционной алгебры
Реляционная алгебра представляет собой совокупность операций над отношениями. Операндами и результатами операций являются отношения. Рассмотрим основные операции реляционной алгебры
Основы реляционного исчисления
Реляционное исчисление это математический аппарат, который позволяет путем использования исчисления предикатов, кванторов и переменных описывать отношения и операции над ними в виде
Общая характеристика и стандарты языка SQL
Язык SQL (Structered Query Language) впервые появился в рамках проекта разработки экспериментальной реляционной СУБД System R в исследовательской лаборатории фирмы IBM в 1975-1979 г
Внешнее соединение таблиц
Рассмотренные соединения называют внутренними (INNER JOIN). В некоторых случаях требуются соединения другого вида – внешние соединения (OUTER JOIN). Рассмотрим две таблицы A (Stud,
Вложенные запросы на чтение
В SQL существуют вложенные запросы, позволяющие использовать результаты одного запроса в качестве составной части другого. Вложенные запросы или подзапросы обладают следующими преим
Целостность данных
Термин “целостность данных” относится к правильности и полноте информации, содержащейся в БД. Вероятно, корректнее говорить о непротиворечивости данных, поскольку невозможно предотв
Триггеры и хранимые процедуры
Как уже говорилось, целостность данных часто связана с порядками и правилами в конкретной организации. Например:
· клиенты не могут размещать заказы на сумму, превышающую и
Обработка транзакций
Транзакцией называются несколько последовательных операторов SQL, которые рассматриваются как единое целое. В транзакции каждый оператор решает часть общей задачи, но для того, чтоб
Представления и работа с ними
Представлением (VIEW) называется SQL-запрос на чтение, которому присвоили имя и сохранили в БД. Представление является виртуальной таблицей, то есть обеспечивает доступ к результата
Обеспечение безопасности баз данных в SQL
Под безопасностью БД понимают защиту данных от несанкционированного чтения, изменения или уничтожения. Язык SQL позволяет индивидуально защищать как целые таблицы, так и отдельные и
Динамический SQL
Рассмотренные возможности SQL реализуются в так называемом статическом SQL. В каждом встроенном операторе программист заранее указывает, на какие таблицы и столбцы он будет ссылать
Элементы языка QBE
Язык QBE (Query By Example – запрос по образцу) был разработан в компании IBM в 1975 году. Это язык реляционного исчисления с переменными на доменах, рассчитанный на работу в интера
Подходы к оптимизации запросов
Говоря про оптимизацию запросов в реляционных СУБД, обычно имеют в виду такой способ обработки, когда по начальному представлению запроса путем преобразований вырабатывается процеду
Новости и инфо для студентов