
- •1.Основные понятия и определения курса. Традиционные файловые системы.
- •5 История развития субд Oracle.
- •6 Общие сведения об инструкциях sql. Правила именования таблиц и столбцов
- •7 Общие сведения о dml.
- •8 Общий синтаксис инструкции select
- •9 Предложения select и from. Предикаты и вычисляемые столбцы (пример).
- •10 Предложение where и классификация условий отбора (привести примеры).
- •11 Составные условия отбора. Влияние значений null на результат отбора.
- •12 Многотабличные запросы и их особенности (привести пример).
- •13 Операторы комбинирования результирующих таблиц в многотабличных запросах (привести примеры).
- •14 Предложение group by. Статистические (агрегативные) функции в sql (примеры).
- •15 Условия отбора групп (предложение having)
- •16 Сортировка результатов запроса (предложение order by).
- •17 Подзапросы: типы, примеры, правила и ограничения, ключевые слова any, all, exist, not exist
- •18 Добавление данных (инструкции insert, merge).
- •19 Модификация и удаление данных (инструкции update, merge и delete).
- •20 Общие сведения о ddl.
- •21 Типы данных sql.
- •22 Создание таблиц (инструкция create table).
- •23 Изменение определения и удаление таблицы (инструкции alter ,drop table).
- •24 Создание псевдонимов и индексов таблиц (инструкции create/drop alias, create/drop index)
- •25 Создание представлений (инструкция create view). Преимущества и недостатки использования, основные виды
- •26 Проблемы обновления и удаление представлений.
- •27 Принципы защиты данных в sql: аутентификация пользователей, защищаемые объекты, использование привилегий и другие возможности обеспечения безопасности
- •28 Аутентификация. Создание и изменение пользователей. Аутентификация пользователей
- •29 Профили. Создание, изменение, удаление.
- •30 Привилегии. Системные привилегии.
- •31 Привилегии доступа к объектам схемы. Правила предоставления привилегий
- •32 Предоставление и отмена привилегий (инструкция grant и revoke).
- •33 Работа с привилегиями при помощи ролей. Системные роли, определение, изменение, удаление ролей
- •34 Аудит. Типы и применение аудита.
- •Типы аудита. В диспетчере авторизации можно использовать два вида аудита: аудит времени выполнения и аудит изменения хранилища данных авторизации. Аудит времени выполнения
- •Аудит изменений хранилища данных авторизации
- •35 Условия целостности данных
- •36 Правила добавления и удаления. Проблемы ссылочных циклов
- •37 Понятие транзакций. Инструкции обработки транзакций (commit и rollback)
- •38 Модель транзакции в стандарте ansi/iso
- •39 Журнал транзакций. Проблемы обработки параллельных транзакций.
- •40 Блокировки транзакций: уровни и виды, тупиковые ситуации.
- •41 Преимущества pl/sql и общие сведения о структуре pl/sql программ
- •42 Классификация блоков pl/sql.
- •43 Управление блоками в sql*Plus.
- •44 Лексические единицы pl/sql
- •45 Синтаксис объявления переменных, инициализация.
- •46 Скалярные типы pl/sql.
- •48 Коллекции (составные типы pl/sql).
- •Методы, применяемые при работе с коллекциями
- •Инициализация коллекций
- •50 Массовое связывание.
- •51 Преобразование типов данных. Область действия и область видимости переменных. Выражения и операции.
- •52 Управляющие структуры pl/sql. Область действия счетчика цикла, ограничения безусловных переходов условное управление
- •Итерационное управление
- •53 Понятие транзакции и виды блокировок Oracle
- •54 Операторы управления транзакциями в Oracle (commit, rollback, savepoint, set transaction, lock table).
- •55 Многоверсионная модель согласованности Oracle.
- •56 Автономные транзакции. Понятие прагмы.
- •57 Записи pl/sql. Использование %rowtype
- •58 Курсорные типы, переменные и выражения. Виды и назначение курсоров.
- •59 Обработка явных и неявных курсоров.
- •61 Динамический sql: использование пакета dbms_sql.
- •62 Алгоритма обработки данных в dbms_sql
- •63 Встроенный динамический sql (nds). (операторы execute immediate, open … for).
- •65 Классификация и определение программных единиц. Общие ключевые слова.
- •66 Создание и использование процедур
- •Вызов процедур и функций
- •67 Создание и использование (вызов) функций.
- •Вызов процедур и функций
- •68 Структура и определение пакета.
- •69 Триггеры бд: виды и создание
- •70 Последовательность событий и предикаты триггеров.
- •71 Пакет dbms_output.
- •72 Пакет utl_file(файловый ввод/вывод)
- •Безопасность
- •73 Пакет dbms_pipe: посылка и получение сообщений
- •74 Пакет dbms_pipe: создание программных каналов и управление ими.
- •75 Архитектура odbc и коды возврата
- •76 Основной алгоритм программ odbc. Инициализация и завершение.
- •77 Выполнение операторов: функции управления каталогом.
- •78 Непосредственное и подготавливаемое выполнение.
- •79 Выборка результатов.
- •80 Подробный алгоритм использования odbc в прикладных программах.
76 Основной алгоритм программ odbc. Инициализация и завершение.
Любая программа с использованием ODBCможет быть разделена на триосновныечасти: инициализация, обработкаSQL– оператора и завершение программы. Главная часть программыODBCэто обработкаSQL– оператора. ВODBC, так же как и вPL/SQLпри обработке произвольногоSQL-оператора, необходимо выполнять связывание параметров. Связывание выполняет драйверODBC.
Прежде чем прикладная программа сможет вызвать какую-либо из функций ODBC, она обязана выполнить инициализациюODBCи установить окружение.ODBCиспользует окружение для отслеживания соединений с базой данных, установленного прикладной программой. Назначение окружения производится функциейODBCSQLAllocEnv()и имеет следующий синтаксис:RETCODESQLAllocEnv(phenv)
RETCODESQLFreeConnect(hdbc)
Здесь параметр HDBC– входной параметр представляющий освобождаемое соединение. Освобождение идентификатора соединения производится после разрыва соединения с источником данныхODBCна этапе завершения, когда необходимо освободить все ресурсы занятые прикладной программой.
77 Выполнение операторов: функции управления каталогом.
В данном разделе рассмотрим два набора функций: функции управления каталогом и выполнения SQL– операторов. Функции управления каталогом возвращают информацию из системного каталога источника данных: имена таблиц, столбцов, табличную статистику и т. д.
Любая функция, которая имеет отношение к обработке или передаче SQL– оператора, требует в качестве параметра идентификатор оператора. Идентификатор оператора аналогичен идентификатору окружения или соединения за исключением того, что он ссылается наSQL– оператор
Назначение идентификатора оператора производится вызовом SQLAllocStmt(), которая выделяет область хранения в памяти для идентификатора оператора и связывает его с соединением, которое определяется собственным идентификатором.
Синтаксис для SQLAllocStmt() имеет вид:
RETCODESQLAllocStmt(hdbc,phstmt)
Парная для SQLAllocStmt() функцияSQLFreeStmt()выполняет следующие действия:
• останавливает любые SQL– операторы, которые в данный момент обрабатываются и связаны с заданным идентификатором оператора,
• закрывают любые открытые курсоры, которые имеют отношение к определенному идентификатору оператора,
• отбрасывает ожидаемые результаты,
• дополнительно, освобождает все ресурсы, связанные с определенным идентификатором оператора.
Синтаксис SQLFreeStmt() имеет следующий вид:
RETCODESQLFreeStmt(hstmt,fOption)
Опция SQL_CLOSEотбрасывает неизвлечённые результаты и закрывает любые связанные с ними курсоры. . Эта опция не влияет на соответствующие параметры, подготовленные операторы или соответствующие столбцы результата.
SQL_DROPосвобождает все ресурсы, связанные с идентификатором, закрывает курсор, если он открыт и отбрасывает все ожидаемые строки результирующего множества. Эта опция завершает все обращения кhstmt, так как после успешного вызоваSQLFreeStmtс этим параметром, идентификатор становится недействительным.
SQL_UNBINDосвобождает (“отвязывает”) все буферы столбцов, связанные со столбцами результирующего множества запроса посредствомSQLBindCol(). Описание данной функции приведено в разделе 2.5 данного методического пособия.
SQL_RESET_PARAMSосвобождает все буферы параметров с фактическими значениями, связанные с маркерами параметров строки запроса. Связывание формальных параметров запроса (маркеров) с буферами фактических значений производится функциейSQLBindParametr(), описание которой приводится ниже в данном разделе.
Управление каталогом
Первая информация, которая может понадобиться прикладной программе для соединения с неизвестным источником данных – это информация о таблицах. ODBC-функцияSQLTablesвозвращает список имен таблиц, которые содержит указанный источник данных.
. Синтаксис SQLTables имеет вид:
RETCODE SQLTables (hstmt, szTableQualifier, sbTableQualifier,
szTableOwner, sbTableOwner, szTableName,
sbTableName, szTableType, sbTableType)