Динамический SQL - раздел Программирование, Среда Delphi широко известна и не вызывает дополнительных трудностей при изучении и использовании Рассмотренные Возможности Sql Реализуются В Так Называемом Статическо...
Рассмотренные возможности SQL реализуются в так называемом статическом SQL. В каждом встроенном операторе программист заранее указывает, на какие таблицы и столбцы он будет ссылаться. Входные переменные придают некоторую гибкость, но не могут решить всех проблем. Если программа только на этапе выполнения может определить, какие операторы SQL применять и на какие таблицы ссылаться, то статический SQL для нее непригоден. В подобных случаях требуется динамический SQL.
Концепция, лежащая в основе динамического SQL, проста: встроенный оператор SQL не записывается в исходный текст программы, а формируется в процессе ее выполнения. Рассматривая различия между статическим и динамическим SQL, можно провести аналогию с ранним и поздним связыванием параметров вызова методов в объектно-ориентированном программировании. В статическом SQL запрос готовится к выполнению на стадии компиляции, а в динамическом SQL некоторые процессы переносятся на стадию выполнения программы. Рассмотрим, не вдаваясь в подробности, основные операторы динамического SQL, определенные стандартом SQL92.
Наиболее простой формой динамического SQL является оператор EXECUTE IMMEDIATE (выполнить немедленно). Программа передает на исполнение оператор SQL, сформированный предварительно в виде текстовой строки и не яляющийся запросом на чтение. Оператор EXECUTE IMMEDIATE обеспечивает одноэтапное выполнение динамического оператора.
Если в программе должны выполняться однотипные операторы SQL, можно по команде PREPARE единственный раз произвести синтаксический разбор и оптимизацию оператора. Оператор EXECUTE в этом случае использует проведенную работу и может выполняться многократно с разными параметрами. Этот двухэтапный метод выполнения запроса способствует уменьшению объема вычислений программы.
Операторы EXECUTE IMMEDIATE и EXECUTE не поддерживают динамические запросы на чтение, поскольку у них отсутствует механизм обработки результатов запроса. Для реализации динамических запросов на чтение используется аппарат курсоров. Программа может не знать заранее, с какими таблицами и столбцами оперирует запрос. Оператор DESCRIBE служит для получения из СУБД описания динамического запроса, ранее подготовленного оператором PREPARE. Описание запроса содержится в специальной области СУБД, называемой дескриптором. Как и ранее, выполнение запроса на чтение инициируется при открытии соответствующего курсора оператором OPEN.
В настоящее время список источников по теории и практике использования баз... В данном пособии подробно излагаются вопросы связанные с проектированием и нормализацией базы данных реляционной...
Если Вам нужно дополнительный материал на эту тему, или Вы не нашли то, что искали, рекомендуем воспользоваться поиском по нашей базе работ:
Динамический SQL
Что будем делать с полученным материалом:
Если этот материал оказался полезным ля Вас, Вы можете сохранить его на свою страничку в социальных сетях:
История создания баз данных
Существуют различные определения базы данных. Обычно они либо неполны, либо слишком громоздки. Дадим простое определение, расширяя его по мере появления новых понятий.
Модели данных СУБД
Коцептуальной моделью данных в БД называют глобальное логическое описание данных. Структуры данных коцептуальной модели влияют на все характеристики СУБД, охватывая
· языки
Двенадцать правил Кодда для реляционных СУБД
В статье, опубликованной в 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 в программном режиме является не одна строка, а целая таблица, необходимо обеспечить для прикладной программы возможность построчного получе
Элементы языка QBE
Язык QBE (Query By Example – запрос по образцу) был разработан в компании IBM в 1975 году. Это язык реляционного исчисления с переменными на доменах, рассчитанный на работу в интера
Подходы к оптимизации запросов
Говоря про оптимизацию запросов в реляционных СУБД, обычно имеют в виду такой способ обработки, когда по начальному представлению запроса путем преобразований вырабатывается процеду
Новости и инфо для студентов