Краткий справочник по Oracle7
1. Введение 2. Имена объектов базы данных 3. Зарезервированные слова Oracle7 и PL/SQL
![]()
В справочник включены краткие сведения о языке PL/SQL, синтаксис предложений
и некоторых фраз языка SQL (подробно они будут описаны в другом документе),
краткие описания конструкций, включаемых в эти языки, а также информация о
Имена объектов базы данных (таблиц, представлений, последовательностей,
"снимков", пакетов, процедур и функций) должны содержать не более 30 символов
и начинаться с буквы. После начальной буквы имя может любые содержать буквы,
цифры и символы "$", "#", и "_", однако полученное сочетание (имя) не может
быть зарезервированным словом Oracle (см. п. 3). Если же возникает необходимость
использовать в имени любые символы кроме кавычек и (или) составлять его из
нескольких слов, то такое имя надо заключить в кавычки (например, "Это имя
столбца".
Имя базы данных не должно превышать 8 символов.
3. Зарезервированные слова Oracle7 и PL/SQL
SQL резервные слова (слова отмеченные * используются также в PL/SQL):
ACCESS* DEFAULT* INTEGER OPTION* START*
ADD* DELETE* INTERSECT* OR* SUCCESSFUL
ALL* DESC* INTO* ORDER* SYNONYM
ALTER* DISTINCT* IS* PCTFREE* SYSDATE
AND* DROP* LEVEL* PRIOR* TABLE*
ANY* ELSE* LIKE* PRIVILEGES THEN*
AS* EXCLUSIVE LOCK PUBLIC* TO*
ASC* EXISTS* LONG RAW TRIGGER
AUDIT FILE MAXEXTENTS RENAME* UID
BETWEEN* FLOAT MINUS* RESOURCE* UNION*
BY* FOR* MODE REVOKE UNIQUE*
CHAR* FROM* MODIFY ROW UPDATE*
CHECK* GRANT* NOAUDIT ROWID USER
CLUSTER* GROUP* NOCOMPRESS* ROWLABEL VALIDATE
COLUMN HAVING* NOT* ROWNUM* VALUES*
COMMENT IDENTIFIED* NOWAIT ROWS VARCHAR*
COMPRESS* IMMEDIATE NULL* SELECT* VARCHAR2*
CONNECT* IN* NUMBER* SESSION VIEW*
CREATE* INCREMENT OF* SET* WHENEVER
CURRENT* INDEX* OFFLINE SHARE WHERE*
DATE* INITIAL ON* SIZE* WITH*
DECIMAL INSERT ONLINE SMALLINT
PL/SQL резервные словаABORT CREATE GOTO PACKAGE SUM
ACCEPT CURRENT GRANT PARTITION TABAUTH
ACCESS CURSOR GROUP PCTFREE TABLE
ADD DATABASE HAVING PRAGMA TABLES
ALL DATA_BASE IDENTIFIED PRIOR TASK
ALTER DATE IF PRIVATE TERMINATE
AND DBA IN PROCEDURE THEN
ANY DEBUGOFF INDEX PUBLIC TO
ARRAY DEBUGON INDEXES RAISE TRUE
AS DECLARE INDICATOR RANGE TYPE
ASC DEFAULT INSERT RECORD UNION
ASSERT DEFINITION INTERSECT RELEASE UNIQUE
ASSIGN DELAY INTO REM UPDATE
AT DELETE IS RENAME USE
AUTHORIZA DELTA LEVEL RESOURCE VALUES
TION DESC LIKE RETURN VARCHAR
AVG DIGITS LIMITED REVERSE VARCHAR2
BEGIN DISPOSE LOOP REVOKE VARIANCE
BETWEEN DISTINCT MAX ROLLBACK VIEW
BODY DO MIN ROWNUM VIEWS
BOOLEAN DROP MINUS ROWTYPE WHEN
BY ELSE MOD RUN WHERE
CASE ELSIF NEW SAVEPOINT WHILE
CHAR END NOCOMPRESS WSCHEMA WITH
CHAR_BASE ENTRY NOT SELECT WORK
CHECK EXCEPTION NULL SEPARATE XOR
CLOSE EXCEP NUMBER SET
CLUSTER TION_INIT NUMBER_BASE SIZE
CLUSTERS EXISTS OR SPACE
COLAUTH EXIT ON SQL
COLUMNS FALSE OPEN SQLCODE
COMMIT FETCH OPTION SQLERRM
COMPRESS FOR OR START
CONNECT FORM ORDER STATEMENT
CONSTANT FROM OTHERS STDDEV
COUNT FUNCTION OUT SUBTYPE
CRASH GENERIC
4. Литералы, операторы и выражения
[ ] - в эти скобки заключаются необязательные синтаксические единицы
{ } - конструкция, заключенная в эти скобки, должна рассматриваться как
одна синтаксическая единица
| - используется для разделения альтернативных синтаксических единиц
... - указывает на то, что непосредственно предшествующая синтаксическая
единица может повторяться один или несколько раз
text - '[символ | '']...'
integer - цифра[цифра]...
number - [+|-]{цифра[цифра]...[.][цифра]...
|.цифра[цифра]...}[{e|E}[+|-]цифра[цифра]...]
expr - любое выражение
Expr_list - (expr [, expr] ...)
Оператор Описание
----------- ------------------------------------------------
() Подавляет обычные правила старшинства операций.
** NOT Возведение в степень и логическое отрицание.
+ - Знак, предшествующий числовому выражению.
* / Умножение и деление.
+ - Сложение и вычитание.|| Сочленение текстовых выражений и (или) констант.
:= Присвоение значения переменной пользователя.
=, <>, <,
>, <=, >=, Операторы сравнения,
IS NULL, используемые при
LIKE, IN, построении условий
BETWEEN
AND Логическое "И"
OR Логическое "ИЛИ"
4.3. Синтаксис выражений (expr)
1-я форма: { [[schema.]{table | view | snapshot }.]
{column | pseudo-column | ROWLABEL}
| 'text' | number | sequence.{CURRVAL | NEXTVAL} | NULL }
2-я форма: function_name [( [DISTINCT | ALL] expr [, expr] ... )]
3-я форма: { (expr) | +expr | -expr | PRIOR expr | expr * expr | expr / expr
| expr + expr | expr - expr | expr || expr }
Decode_expr: DECODE( expr, search, result [, search, result] ... [, default] )
Если значение expr = search, то возвращает значение result, иначе
значение default или NULL (при отсутствии default).
4.4. Синтаксис условий (condition)
1-я форма: { expr {= | <> | >
| < | >= | <=}{expr | (subquery)} | expr_list {= | <>} (subquery) }
2-я форма: { expr {= | <> | > | < | >= | <=}
{ANY | SOME | ALL} {expr_list | (subquery)} | expr_list {= | <>}
{ANY | SOME | ALL} ( { expr_list [, expr_list] ... | subquery} ) }
3-я форма: { expr [NOT] IN {expr_list | (subquery)}
| expr_list [NOT] IN ( { expr_list [, expr_list]... | subquery} ) }
4-я форма: expr [NOT] BETWEEN expr AND expr
5-я форма: expr IS [NOT] NULL
6-я форма: EXISTS (
subquery)7-я форма: char1 [NOT] LIKE char2 [ESCAPE 'c']
8-я форма: { ( условие )
| NOT условие
| условие AND условие
| условие OR условие }
NOT Реверсирование результата логического выражения (условия).
NOT | true false null
------|-------------------
| false true null
AND Логическая операция "И" соединяющая два или несколько условий
(логических выражений). В зависимости от истинности (true) или
ложности (false) этих условий результат определяется по правилам:
AND | true false null
------|--------------------
true | true false null
false | false false false
null | null false null
OR Логическая операция "ИЛИ" соединяющая два или несколько условий
(логических выражений). В зависимости от истинности (true) илиложности (false) этих условий результат определяется по правилам:
OR | true false null
------|-------------------
true | true true true
false | true false null
null | true null null
4.6. Операторы, используемые в предложении SELECT
UNION Объединение двух запросов; результат состоит из неповторяющиеся строк,
выданных каждым из объединяемых запросов.
UNION ALL Объединение двух запросов; результат состоит из всех строк, выданных
каждым из объединяемых запросов.
INTERSECT Комбинация двух запросов; результат состоит из строк, которые выданы
как первым, так и вторым запросом.
MINUS Комбинация двух запросов; результат состоит из строк, которые выданы
первым запросом, но не выданы вторым запросом.
(+) Оператор внешнего соединения.
* Заменяет список имен всех столбцов таблицы или представления.
PRIOR Используется в древовидных структурах для указания направления
просмотра: от корня до листьев или от листьев до корня.
ALL Сохраняет дубликаты строк в результате запроса (ALL устанавливается
по умолчанию).
DISTINCT Исключает дубликаты строк из результата запроса.
Тип данных Описание
---------------- -------------------------------------------------------------
CHAR(размер) Используется для хранения текстовых строк фиксированной длины.
По умолчанию размер 1, максимальный размер 255.
DATE Используется для хранения информации о дате и времени (дата,
час, минута и секунда). Интервал дат: 1 января 4712 до н.э.
- 31 декабря 4712 н.э.
LONG Используется для хранения больших строк переменной длины (до
2 гигабайт).
LONG RAW Используется для хранения двоичных строк (до 2 гигабайт).
NUMBER(точность, Служат для хранения чисел всех типов (целые, с плавающей
масштаб) точкой и т.д.). Точность изменяется от 0 до 38 (по умолчанию
38), а масштаб от -84 до 127 (по умолчанию 0). Если задается
отрицательный масштаб, то Oracle7 округляет значение слева отдесятичной точки.
RAW(размер) Применяется для хранения небольших двоичных строк (меньше
2000 байт).
ROWID Используется для хранения шестнадцатиричных значений ROWID.
VARCHAR2(размер) Используется для хранения строк переменной длины. По
умолчанию размер 1, максимальный размер 2000.
Преобразование данных с помощью функций SQL и ORACLE7
To |
From | CHAR DATE NUMBER RAW ROWID
-------|-----------------------------------------------------------
CHAR | TO_DATE TO_NUMBER HEXTORAW CHARTOROWID
DATE | TO_CHAR
NUMBER | TO_CHAR TO_DATE
RAW | RAWTOHEX
ROWID | ROWIDTOCHAR
Допустимые преобразования
To |
From | CHAR DATE LONG NUMBER RAW ROWID VARCHAR2
---------|-----------------------------------------------------
CHAR | yes yes yes yes yes yes
DATE | yes yes yes
LONG | yes yes yes
NUMBER | yes yes yes
RAW | yes yes yes
ROWID | yes yes
VARCHAR2 | yes yes yes yes yes yes
Для включения комментариев в предложения SQL и командные блоки PL/SQL можно
либо расположить текст комментария между парами символов /* и */ (например,
UPDATE Блюда /* Это имя модифицируемой таблицы */ SET ...), либо предварить его
двумя дефисами (например, DELETE FROM Блюда -- Удаление строк таблицы Блюда).
С помощью первого способа можно включать многострочные комментарии. Для
включения многострочных комментариев вторым способом приходится помещать "--"
перед каждой их строкой. Следует заметить, что комментарии, отмеченные "--"
могут располагаться либо в отдельных строках, либо в конце строк текста
комментируемого предложения (строк текста блока PL/SQL).
Функции могут быть использованы везде, где используются переменные, столбцы
или выражения (соответствующего типа). Их обычно подразделяют на числовые, сим-
вольные, групповые (функции SQL), функции работы с датами (дата и время), функ-
ции преобразования, и прочие функции.
В описаниях функций используются следующие параметры:
char,char1,char2,... - константы в апострофах или выражения типа CHAR
d,d1,d2 - константы в апострофах или выражения типа DATE
expr,expr1,expr2,... - любые выражения
fmt - формат данных
k,m,n
- любые числовые константы или выражения типа NUMBER.nls - выражение вида 'NLS_SORT = name'.
raw - исходные данные
rowid - внутренний уникальный идентификатор строки
set,set1,set2 - наборы символов
z1,z2 - часовые пояса (см. "Функции работы с датами и временем")
Функции Возвращаемое значение
------------- ----------------------------------------------------------------
ABS(n) Абсолютное значение n, большее или равное n.
CEIL(n) Наименьшее целое, не меньшее n.
COS(n) Косинус n, заданного в радианах.
COSH(n) Гиперболический косинус n в радианах.
EXP(n) Возведение e (exp) в степень n (где е = 2.7182818).
FLOOR(n) Наибольшее целое, меньшее или равное n.
LN(n) Натуральный логарифм n, где n > 0.
LOG(m,n) Основание m логарифма n.
MOD(m,n) Остаток от деления m на n.
POWER(m,n) m в степени n. Если n не целое, то оно усекается до целого.
ROUND(n[,m])
n, округленное до m-того десятичного знака; если m опущено, тооно принимается равным 0. m может быть отрицательным для округ-
ления цифр левее десятичной точки.
SIGN(n) Если n<0, то -1; если n=0, то 0; если n>0, то 1.
SIN
(n) Синус n, заданного в радианах.SINH(n) Гиперболический синус n в радианах.
SQRT(n) Квадратный корень из n; если n < 0, то NULL.
TAN(n) Тангенс n, заданного в радианах.
TANH(n) Гиперболический тангенс n в радианах.
TRUNC(
n[,m]) n, усеченное до m десятичных знаков; если m опущено, то онопринимается равным 0. m может быть отрицательным для усечения
(обнуления) цифр слева от десятичной точки.
Функция Возвращаемое значение
---------------- -------------------------------------------------------------
ASCII(char) Код ASCII первого символа символьной переменной "char".
CHR(n) Символ, код ASCII которого равен n
CONCAT(char1, Соединяет (конкатенирует) строку "char1" со строкой "char2".
char2) (Эквивалентна выражению: char1 || char2.)
INITCAP(char) Символьная переменная с первыми буквами слов, начинающихся
с заглавной буквы.
INSTR(char1, Позиция m-того включения "char2" в "char1" при начале поиска
char2[,n[,m]]) с позиции n. Если m опущено, по умолчанию предполагается 1;
аналогично для n. Позиции даются относительно первого знака
"char1", даже если n > 1.
INSTRB(char1, Эквивалентна INSTR, но n и результат возвращаются в байтах,
char2[,n[,m]]) а не в позициях символов. Эту функцию полезно использовать
при работе с многобайтовыми символьными строками.
LENGTH(char) Длина в знаках символьной переменной "char".
LEN
GTHB(char) Длина в байтах символьной переменной "char".LOWER(char) "char", где все буквы преобразованы в строчные (маленькие).
LPAD(char1,n Строка "char1", дополненная слева до длины n последователь-
[,char2]) ностью символов из строки "char2" с повторением этой после-
довательности столько раз сколько необходимо. Если "char2"
опущено, то для заполнения используются пробелы.
LTRIM(char Удаляет из "char" начальные знаки до тех пор, пока не появит-
[,set]) ся знак, отсутствующий среди знаков "set". При отсутствии"set" из "char" удаляются все левые пробелы.
NLS_INITCAP(char Аналог INITCAP, но необязательный аргумент "nls" позволяет
[,nls]) задать используемый в функции национальный язык.
NLS_LOWER(char Аналог LOWER, но необязательный аргумент "nls" позволяет
[,nls]) задать используемый в функции национальный язык.
NLSSORT(char Байтовая строка, использованная для сортировки "char" на базе
[,nls])
языка, заданного аргументом "nls". Эту функцию полезно приме-нять для сравнения строк в различных языках.
NLS_UPPER(char Аналог UPPER, но необязательный аргумент "nls" позволяет
[,nls]) задать используемый в функции национальный язык.
REPLACE(char1, Строка, полученная из "char1", в которой все вхождения "char2"
char2[,char3]) заменены на "char3". Если "char3" отсутствует,
то все вхождения "char2" в "char1" - удаляются.
RPAD(char1,n строка "char1", дополненная справа символами "char2", с повто-
[,char2]) рением, если необходимо; если "char2" опущена, "char1" допол-
няется пробелами.
RTRIM(char Удаляет из "char" конечные знаки до тех пор, пока не появится
[,set]) знак, отсутствующий среди знаков "set". При отсутствии
"set" из "char" удаляются все правые пробелы.
SOUNDEX(char) Фонетическое представление "char" (четырехсимвольное представ-
ление, показывающее, как звучит начало "char
").SUBSTR(char,m Подстрока, получаемая из "char", начиная с символа m. Если
[,n]) задано n, то подстрока ограничивается n символами. При отри-
цательном m символы отсчитываются с конца "char".
SUBSTRB(char,m Эквивалентно SUBSTR, но аргументы m и n выражаются не в
[,n]) символах, а в байтах. Эту функцию полезно использовать при
работе с многобайтовыми символьными строками.
TRANSLATE(char, строка, полученная трансляцией "char" в наборе "set1" в
set1, set2) наборе "set2".UPPFR(char) строка, полученная из "char" заменой ее строчных букв на
заглавные буквы.
7.3. Функции работы с датами и временем
Функция Возвращаемое значение
----------------- ------------------------------------------------------------
ADD_MONTHS(d,n) Дата d плюс n месяцев.
LAST_DAY(d) Дата последнего дня месяца, заданного датой d.
MONTHS_BETWEEN Количество месяцев между датами d1 и d2. Eсли d1 > d2, то
(d1,d2) результат положителен, иначе отрицателен.
NEW_TIME(d,z1,z2) Преобразует дату и время, заданное d в часовом поясе z1, в
дату и время в часовом поясе z2. Символьные значения z1 и z2
выбираются из следующего списка:
AST,ADT Атлантическое стандартное и дневное время;BST,BDT Берингово стандартное и дневное время;
CST,CDT Центральное стандартное и дневное время;
EST,EDT Восточное стандартное и дневное время;
GMT Среднее время по Гринвичу;
HST,HDT Аляски-Гаваев стандартное и дневное время;
MST,MDT Монтаны стандартное и дневное время;
NST Нью-Фаунленда стандартное время;
PST,PDT Тихоокеанское стандартное и дневное время;
YST,YDT Юкона стандартное и дневное время.
NEXT_DAY(d,char) Дата первого из дней недели, обозначенной "char", которая
больше или равна d.
ROUND(d[,fmt]) Значение d, округленное до ближайшего числа в формате,
заданном "fmt" (например, год или месяц). По умолчанию DD.
SYSDATE Текущая дата и время.
TRUNC(d[,fmt]) Значение d, усеченное до ближайшего числа в формате,
заданном "fmt" (например, год или месяц). По умолчанию DD.
Форматы, используемые в TRUNC и ROUNDИспользуемый формат Значение
--------------------------- ----------------------------------------
CC or SCC Дата первого дня века
YYYY или SYYYY Дата первого дня года (при округлении: до или
YYY или YY или Y после 1-го июля)
Y,YYY или YEAR или SYEAR
Q Дата первого дня квартала (при округлении: до или
после 16-го числа второго месяца квартала)
MONTH или MON или MM или RM Дата первого дня месяца (при округлении: до или
после 16-го числа месяца)
WW or IW Дата первого дня недели, начинающейся не с
воскресения, а с дня недели определенного по
первому дню года (при округлении: до или после
4-го дня недели)
W
Дата первого день недели, начинающейся не своскресения, а с дня недели определенного по
первому дню месяца (при округлении: до или после
4-го дня недели
)DDD or DD or J Номер дня
DAY or DY or D Дата первого дня недели (воскресения)
HH or HH12 or HH24 Час
MI Минута
Функция Возвращаемое значение
--------------------- --------------------------------------------------------
CHARTOROWID(char) Идентификатор строки (тип данных ROWID) из строки "char".
CONVERT(char,set1 Преобразованное "char" (по набору символов "set1"). Нео-
[,set2]) бязательный аргумент "set2" задает исходный набор символов.
HEXTORAW(char) Строка "char", преобразованная из шестнадцатиричного
представления в двоичное - удобное для включения в RAW-
столбец (столбец с исходными данными).
RAWTOHEX(raw) Строка шестнадцатиричных значений, получаемая из "raw"
(исходные данные).
ROWIDTOCHAR(rowid) Символьная строка длиной 18 символов, полученная "rowid"
(идентификатор строки).
TO_CHAR(expr[,fmt "expr" преобразуется из числового значения или даты в
[,nls]]) символьную строку по формату, заданному в "fmt". Необя-
зательный аргумент "nls" позволяет задать используемый
в функции национальный язык. Если "fmt" опущено, то чис-
ловое "expr" преобразуется в строку такой длины, кото-
рая вмещает только значащие цифры; дата же преобразуется
по формату даты согласно умолчанию: 'DD-MON-YY'.
TO_DATE(char[,fmt Преобразование даты в символьном виде в значение даты по
[,nls]]) формату, заданному в "fmt". Необязательный аргумент
"nls" позволяет задать используемый в функции нацио-
нальный язык. Если "fmt" опущена,"char" должна иметьформат даты по умолчанию: 'DD-MON-YY'.
TO_MULTI_BYTE(char) Преобразование "char" с однобайтовыми символами в
многобайтовые символы.
TO_NU
MBER(char[,fmt Преобразование "char" в число по формату "fmt". Нео-[,nls]]) обязательный аргумент "nls" позволяет задать исполь-
зуемый в функции национальный символ валюты.
TO_SINGLE_BYTE(char) Преобразование "char" с многобайтовыми символами в
однобайтовые символы.
Групповые функции имеют значение только в запросах и подзапросах.
Использование DISTINCT позволяет учитывать только различающиеся значения
аргумента "expr". При указании ALL (или по умолчанию) учитываются все значения
"expr". Например, DISTINCT при нахождении среднего значения из 1,1,1, и 3
дает результат 2, тогда как ALL при этой же операции дает результат 1.5.
Функция Возвращаемое значение
------------------- ----------------------------------------------------------
AVG([DISTINCT| Среднее значение "expr", с игнорированием пустых
ALL]expr) (NULL) значений
COUNT({[DISTINCT| Количество строк, в которых "expr" не является пустым
ALL]expr|*}) (NULL) значением. Установка "*" позволяет подсчитать
все выбранные строки, включая строки с NULL значениями
MAX([DISTINCT| Максимальное значение "expr"
ALL]expr)
MIN([DISTINCT| Минимальное значение "e
xpr"ALL]expr)
STDDEV([DISTINCT| Среднеквадратичное (стандартное) отклонение от "expr"
ALL]expr) с игнорированием пустых (NULL) значений
SUM([DISTINCT| Cумма значений "expr"
ALL]expr)
VARIANCE([DISTINCT| Дисперсия "expr", с игнорированием пустых значений
ALL]expr)
Функция Возвращаемое значение
--------------- --------------------------------------------------------------
DUMP(expr[,k Строка символов, содержащая код типа данных, длину в байтах
[,m[,n
]]] ) и внутреннее представление "expr". Необязательный аргументk позволяет задать представление возвращаемого значения:
8 - восьмеричное, 10 - десятичное, 16 - шестнадцатиричное,
17 - одиночные символы. Необязательный аргумент m задает
начальную позицию в "expr", а необязательный аргумент n
- длину возвращаемого значения, начиная с m.
GREATEST(expr1, Наибольшее значение из перечня. Пеpед сpавнением все выра-
expr2,...)
жения пpеобpазуются к типу пеpвого выpажения.LEAST(expr1, Наименьшее значение из перечня. Пеpед сpавнением все выра-
expr2,...) жения пpеобpазуются к типу пеpвого выpажения.
NVL(n,expr) Если n равно NULL, возвpащает "expr", иначе возвращает n
.n и "expr" могут быть любого типа. Тип возвpащаемой вели-
чины такой же как для n.
UID Целое число, уникальным образом идентифицирующее текущего
пользователя.
USER Имя текущего пользователя.
USERNV(char) Информация о среде текущего сеанса. Если "char" равен:
'ENTRYID' - возвращается доступный идентификатор элемента,
за которым идет слежение;
'LANGUAGE' - возвращает используемый язык;
'SESSIONID' - возвращается идентификатор сеанса пользователя;
'TERMINAL' - возвращается идентификатор терминала пользо-
вателя (в терминах операционной системы).
VSIZE(expr)
Число байтов во внутpеннем пpедставлении "expr".8.1. Числовые форматы (для fmt аргумента функции TO_CHAR)
Элемент Пример Описание
------- --------- ----------------------------------------------------------
9 9999 Количество цифр, определяющих ширину вывода.
0 0999 Вывод ведущих нулей.
$ $9999 Вывод перед значением знака доллара.
B B9999 Вывод пробелов вместо ведущих нулей.
MI 9999MI Вывод знака "-" после отрицательных чисел.
S S9
999 Вывод "+" для положительных чисел и "-" для отрицательных.PR 9999PR Вывод отрицательных чисел в <угловых скобках>.
D 99D99 Вывод десятичного разделителя.
G 9G999 Вывод разделителя групп (например, триад в денежных данных).
C C999 Вывод символа интернациональной денежной единицы.
L L999 Вывод конкретного денежного символа.
Запятая 9,999 Вывод запятой в указанной позиции.
Точка 99.99 Вывод точки в указанной позиции.
V 999V99 Умножение на 10 в N-ой степени, где N - задается в виде
количества девяток после 'V'.
EEEE 9&999EEEE Вывод в экспоненциальной форме.
RN (rn) RN upper- or lower-case Roman numerals (numbers in range 1..3999).
DATE 'DATE` Returns value converted from Julian date to 'MM/DD/YY' date format.
DATE DATE Высвечивание в формате даты 'MM/DD/YY'. Для дат,хранящихся
как числовые величины (ORACLE версия 2).
Символьный формат состоит из буквы 'A' и следующего за ней указания ширины
строки, столбца или выражения в символах. Если значение не укладывается в
указанную ширину, оно будет сдвинуто или обрезано в зависимости от того была
ли выполнена установка SET WRAP или SET TRUNC.
Формат Описание
------------------- ----------------------------------------
SCC или СС Век; 'S'- префикс перед датой (до н.э.) с'-'.
YYYY или SYYYY Год; 'S'- префикс перед датой (до н.э.) с'-'.
YYY или YY или Y Последние 3, 2 или 1 цифра(ы) года.
IYYY 4-цифры года в стандарте ISO.
IYY или IY или I Последние 3, 2 или 1 цифра(ы) года в стандарте ISO.
Y,YYY Год с запятой в данной позиции.
SYEAR или YEAR Год прописью. 'S'-префикс перед датой (до н.э.) с'-'.
BC или AD BC/AD - (до н.э.) / ( н.э.).
B.C. или A.D. Аналогично BC/AD.
Q Квартал (четверть) года.
MM Номер месяца.
RM Номер месяца римскими цифрами (I..XII; JAN=
I).MONTH Имя месяца, дополненное пробелами до девяти символов.
MON Трехбуквенная аббревиатура имени месяца (JAN,FEB,...).
WW или W Неделя года (1-52) или месяца (1-5).
IW Неделя года в стандарте ISO (1..21 или 1..53).
DDD DD или D Номер дня года (1-366), месяца (1-31) или недели (1-7).
DAY Наименование дня, дополненное пробелами до 9 символов.
DY Трехбуквенная аббревиатура наименования дня.
J
День по Юлианскому календарю; количество дней от31 декабря 4713 до н.э.
AM или PM Указатель часового пояса.
A.M. или P.M. Указатель часового пояса с периодами.
HH или HH12 Время суток, интервал 1-12.
HH24
Время суток, интервал 0-23.MI Минуты (0-59).
SS или SSSSS Секунды (0-59) или после полуночи (0-86399).
-/.,;: Пунктуация, которая воспроизводится в результате.
"...текст..." Строка в кавычках, которая воспроизводится в результате.
8.4. Префиксы и суффиксы, используемые в форматах
Префикс и суффиксы, которые могут быть добавлены к перечисленным выше кодам:
------------------------------------------------------------------------------
FM
"Fill mode" (режим наполнения). Указанный перед MONTH или DAY,подавляет пробелы, оставляя только результат фактической длины.
FX "Format exact". Указанный в начале формата для функции TO_DATE,
проверяет соответствует ли преобразуемое значение заданному
формату. При несоответствии (например, лишние пробелы, другие
разделители и т.п.) - отвергает преобразование.
TH Порядковое число (напр.,"DDTH" для "4TH").
SP Число прописью (напр.,"DDSP" для "FOUR")
SPTH или THSP Порядковое число прописью (напр., "DDSPTH") для "FOURTH").
Наличие заглавных букв в аббревиатурах или в словах прописью определяется
наличием заглавных букв в соответствующем форматном элементе.
Например, "DAY" дает "MONDAY", "Day" дает "Monday" и "day" дает "monday".
Модель формата даты может также включать в себя знаки пунктуации, такие
как дефис, косую черту, запятые и символьные константы, заключенные в кавычки
(не в апострофы). Пунктуация и константы появляются при выводе.
Например, DDth "of" Month, YYYY дает 15th of February, 1986.
Имя столбца Значение
---------------- ------------------------------------------------------------
sequence.CURRVAL
Текущее значение последовательности для текущего сеанса(sequence.NEXTVAL должно быть объявлено первым)
sequence.NEXTVAL Следующее значение последовательности для текущего сеанса
table.LEVEL 1 - для корня, 2 - для дочернего уровня корня и т.д.
(используется в команде SELECT ... CONNECT BY,
реализующей иерархические структуры)
[table.]ROWID Уникальный идентификатор строки таблицы, составленный из
трех шестнадцатиричных значений: BBBBBBB.RRRR.FFFF, где
BBBBBBBB - блок в файле, RRRR - номер записи в этом блоке
(начиная с 0) и FFFF - файл базы данных, содержащий эту
таблицу; (например, 0000000E.000A.0007). Для этого
идентификатора существует специальный тип данных ROWID.
ROWNUM Позиция отдельной строки среди строк, отобранных запросом.
Oracle7 выбирает строки в произвольном порядке и оценивает
ROWNUM перед сортировкой с помощью ORDER BY фразы. Однако,
если ORDER BY использует индексы, то порядок ROWNUM может
отличаться от его порядка без индекса.
Таблица DUAL
Автоматически создается Oracle для каждого пользователя. В ней один столбец
с именем DUMMY и типом данных VARCHAR2(1). В единственной строке этой
таблицы хранится значение 'X'. Отметим, что указанное значение и его описание
не имеет большого значения, так как чаще всего эта таблица используется для
вывода значения какого-либо выражения любого типа, например
SELECT TO_CHAR(SYSDATE, 'DD-MM-YYYY HH24:MI:SS') FROM DUAL;
10. Предложения (команды) SQL Oracle7
ALTER CLUSTER [schema.]cluster
[PCTUSED integer] [PCTFREE integer] [SIZE integer [K|M] ]
[INITRANS integer] [MAXTRANS integer] [STORAGE storage_clause]
[ALLOCATE EXTENT [( [SIZE integer [K|M] ]
[DATAFILE 'filename'] [INSTANCE integer] )]
ALTER DATABASE [database]
{ MOUNT [!!under!!EXCLUSIVE | PARALLEL] | CONVERT
| OPEN [RESETLOGS | NORESETLOGS] | ARCHIVELOG
| NOARCHIVELOG | RECOVER recover_clause
| ADD LOGFILE [THREAD integer] [GROUP integer] filespec
[, [GROUP integer] filespec] ...
| ADD LOGFILE MEMBER 'filename' [REUSE]
[, 'filename' [REUSE]] ...
TO { GROUP integer
| ('filename' [,'filename'] ...)
| 'filename' }
[, 'filename' [REUSE]
[, 'filename' [REUSE]] ...
TO { GROUP integer
| ('filename' [, 'filename'] ...)
| 'filename' } ] ...
| DROP LOGFILE { GROUP integer
| ('filename' [, 'filename'] ...)
| 'filename' }
[, { GROUP integer
| ('filename' [,'filename'] ...)
| 'filename' } ] ...
| DROP LOGFILE MEMBER 'filename' [, 'filename'] ...
| RENAME FILE 'filename' [, 'filename'] ...
TO 'filename' [, 'filename'] ...
| BACKUP CONTROLFILE TO { 'filename' [REUSE]
| TRACE [!!under!!NORESETLOGS
| RESETLOGS] }
| CREATE DATAFILE 'filename' [, filename] ...
[AS filespec [, filespec] ...
| DATAFILE 'filename' { ONLINE | OFFLINE [DROP] }
| ENABLE [PUBLIC] THREAD integer
| DISABLE THREAD integer
| RENAME GLOBAL_NAME TO database[.domain]...
| RESET COMPATIBILITY
| SET { DBMAC {ON | OFF} | DBHIGH = 'text' | DBLOW = 'text' } }
ALTER FUNCTION [schema.]function COMPILE
ALTER INDEX [schema.]index
[INITRANS integer] [MAXTRANS integer] [STORAGE storage_clause]
ALTER PACKAGE [schema.]package COMPILE [!!under!!PACKAGE | BODY]
ALTER PROCEDURE [schema.]procedure COMPILE
ALTER PROFILE profile
LIMIT [SESSIONS_PER_USER {integer | UNLIMITED | DEFAULT}]
[CPU_PER_SESSION {integer | UNLIMITED | DEFAULT}]
[CPU_PER_CALL {integer | UNLIMITED | DEFAULT}]
[CONNECT_TIME {integer | UNLIMITED | DEFAULT}]
[IDLE_TIME {integer | UNLIMITED | DEFAULT}]
[LOGICAL_READS_PER_SESSION {integer | UNLIMITED | DEFAULT}]
[LOGICAL_READS_PER_CALL {integer | UNLIMITED | DEFAULT}]
[COMPOSITE_LIMIT {integer | UNLIMITED | DEFAULT}]
[PRIVATE_SGA {integer [K|M] | UNLIMITED | DEFAULT}]
ALTER RESOURCE COST [CPU_PER_SESSION integer]
[CONNECT_TIME integer]
[LOGICAL_READS_PER_SESSION integer]
[PRIVATE_SGA integer]
ALTER ROLE role { NOT IDENTIFIED | IDENTIFIED {BY password | EXTERNALLY }
ALTER ROLLBACK SEGMENT rollback_segment
{ ONLINE
| OFFLINE
| STORAGE storage_clause }
ALTER SEQUENCE [schema.]sequence
[INCREMENT BY integer]
[MAXVALUE integer | NOMAXVALUE]
[MINVALUE integer | NOMINVALUE]
[CYCLE | NOCYCLE]
[CACHE integer | NOCACHE]
[ORDER | NOORDER]
ALTER SESSION
{ SET { SQL_TRACE = { TRUE | FALSE }
| GLOBAL_NAMES = { TRUE | FALSE }
| NLS_LANGUAGE = language
| NLS_TERRITORY = territory
| NLS_DATE_FORMAT = 'fmt'
| NLS_DATE_LANGUAGE = language
| NLS_NUMERIC_CHARACTERS = 'text'
| NLS_ISO_CURRENCY = territory
| NLS_CURRENCY = 'text'
| NLS_SORT = { sort | BINARY }
| LABEL = {'text' | DBHIGH | DBLOW | OSLABEL }
| MLS_LABEL_FORMAT = 'fmt'
| OPTIMIZER_GOAL =
{ RULE|ALL_ROWS|FIRST_ROWS|CHOOSE }
... }
| CLOSE DATABASE LINK dblink
| ADVISE {COMMIT | ROLLBACK | NOTHING}
| {ENABLE | DISABLE} COMMIT IN PROCEDURE }
ALTER SNAPSHOT [schema.]snapshot
[PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[STORAGE storage_clause]
[USING INDEX [INITRANS integer] [MAXTRANS integer]
[STORAGE storage_clause] ]
[REFRESH [FAST | COMPLETE | !!under!!FORCE]
[START WITH date] [NEXT date]]
ALTER SNAPSHOT LOG ON [schema.]table
[PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[STORAGE storage_clause]
ALTER SYSTEM
{ {ENABLE | DISABLE} RESTRICTED SESSION
| FLUSH SHARED_POOL
| {CHECKPOINT | CHECK DATAFILES}
[!!under!!GLOBAL | LOCAL]
| SET { RESOURCE_LIMIT = { TRUE | FALSE }
| GLOBAL_NAMES = { TRUE | FALSE }
| MTS_DISPATCHERS = 'protocol, integer'
| MTS_SERVERS = integer
| LICENSE_MAX_SESSIONS = integer
| LICENSE_SESSIONS_WARNING = integer
| LICENSE_MAX_USERS = integer } ...
| SWITCH LOGFILE
| {ENABLE | DISABLE} DISTRIBUTED RECOVERY
| ARCHIVE LOG archive_log_clause
| KILL SESSION 'integer1, integer2' }
ALTER TABLE [schema.]table
[ADD { { column [datatype] [DEFAULT expr] [column_constraint] ...
| table_constraint }
| ( { column [datatype] [DEFAULT expr] [column_constraint] ...
| table_constraint }
[, { column [datatype] [DEFAULT expr] [column_constraint] ...
| table_constraint } ] ... ) } ]
[MODIFY { column [datatype] [DEFAULT expr] [column_constraint]
| (column [datatype] [DEFAULT expr] [column_constraint]
[, column [datatype] [DEFAULT expr] [column_constraint] ] ...) } ]
[PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[STORAGE storage_clause]
[DROP drop_clause] ...
[ALLOCATE EXTENT [( [SIZE integer [K|M] ]
[DATAFILE 'filename']
[INSTANCE integer] )]
[ ENABLE enable_clause
| DISABLE disable_clause ] ...
ALTER TABLESPACE tablespace
{ ADD DATAFILE filespec [, filespec] ...
| RENAME DATAFILE 'filename' [,'filename'] ...
TO 'filename' [,'filename'] ...
| DEFAULT STORAGE storage_clause
| ONLINE
| OFFLINE [!!under!!NORMAL | TEMPORARY | IMMEDIATE]
| {BEGIN | END} BACKUP
| READ ONLY | READ WRITE }
ALTER TRIGGER [schema.]trigger { ENABLE | DISABLE }
ALTER USER user
[IDENTIFIED {BY password | EXTERNALLY}]
[DEFAULT TABLESPACE tablespace]
[TEMPORARY TABLESPACE tablespace]
[QUOTA {integer [K|M] | UNLIMITED} ON tablespace] ...
[PROFILE profile]
[DEFAULT ROLE { role [, role] ...
| ALL [EXCEPT role [, role] ...] | NONE}]
ALTER VIEW [schema.]view COMPILE
ANALYZE { INDEX [schema.]index
{ { COMPUTE STATISTICS
| ESTIMATE STATISTICS [SAMPLE integer
{ROWS | PERCENT}]
| DELETE STATISTICS }
| VALIDATE STRUCTURE }
| {TABLE [schema.]table | CLUSTER [schema.]cluster}
{ { COMPUTE STATISTICS
| ESTIMATE STATISTICS [SAMPLE integer
{ROWS | PERCENT}]
| DELETE STATISTICS }
| VALIDATE STRUCTURE [CASCADE]
| LIST CHAINED ROWS [INTO [schema.]table] } }
AUDIT {statement_opt | system_priv}
[, {statement_opt | system_priv} ] ...
[BY user [, user] ...]
[BY {SESSION | ACCESS}]
[WHENEVER [NOT] SUCCESSFUL]
AUDIT object_opt [, object_opt] ...
ON { [schema.]object | DEFAULT }
[BY {SESSION | ACCESS}]
[WHENEVER [NOT] SUCCESSFUL]
COMMENT ON { TABLE [schema.]{table | view | snapshot}
| COLUMN [schema.]{table | view | snapshot}.column } IS 'text'
COMMIT [WORK]
[ COMMENT 'text' | FORCE 'text' [, integer] ]
CREATE CLUSTER [schema.]cluster
(column datatype [,column datatype] ... )
[PCTUSED integer] [PCTFREE integer]
[SIZE integer [K|M] ]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause]
[!!under!!INDEX
| [HASH IS column] HASHKEYS integer]
CREATE CONTROLFILE [REUSE]
[SET] DATABASE database
LOGFILE [GROUP integer] filespec [, [GROUP integer] filespec] ...
{RESETLOGS | NORESETLOGS}
DATAFILE filespec [, filespec] ...
[MAXLOGFILES integer] [MAXLOGMEMBERS integer] [MAXLOGHISTORY integer]
[MAXDATAFILES integer] [MAXINSTANCES integer]
[ARCHIVELOG | !!under!!NOARCHIVELOG]
CREATE DATABASE [database]
[CONTROLFILE REUSE]
[LOGFILE [GROUP integer] filespec [,
[GROUP integer] filespec] ...]
[MAXLOGFILES integer ] [MAXLOGMEMBERS integer] [MAXLOGHISTORY integer]
[DATAFILE filespec [, filespec] ...]
[MAXDATAFILES integer] [MAXINSTANCES integer]
[ARCHIVELOG | !!under!!NOARCHIVELOG]
[!!under!!EXCLUSIVE]
[CHARACTER SET charset]
CREATE [PUBLIC] DATABASE LINK dblink
[CONNECT TO user IDENTIFIED BY password]
[USING 'dbstring']
CREATE [OR REPLACE] FUNCTION [schema.]function
[ (argument [!!under!!IN] datatype
[, argument [!!under!!IN] datatype] ...)]
RETURN datatype
{IS | AS} pl/sql_subprogram_body
CREATE INDEX [schema.]index
ON { [schema.]table (column [!!under!!ASC|DESC]
[, column [!!under!!ASC|DESC]] ...)
| CLUSTER [schema.]cluster }
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause]
[PCTFREE integer]
[NOSORT]
CREATE [OR REPLACE] PACKAGE [schema.]package
{IS | AS} pl/sql_package_spec
CREATE [OR REPLACE] PACKAGE BODY [schema.]package
{IS | AS} pl/sql_package_body
CREATE [OR REPLACE] PROCEDURE [schema.]procedure
[ (argument [!!under!!IN | OUT | IN OUT] datatype
[, argument [!!under!!IN | OUT | IN OUT] datatype] ...)]
{IS | AS} pl/sql_subprogram_body
CREATE PROFILE profile
LIMIT [SESSIONS_PER_USER {integer | UNLIMITED | DEFAULT}]
[CPU_PER_SESSION {integer | UNLIMITED | DEFAULT}]
[CPU_PER_CALL {integer | UNLIMITED | DEFAULT}]
[CONNECT_TIME {integer | UNLIMITED | DEFAULT}]
[IDLE_TIME {integer | UNLIMITED | DEFAULT}]
[LOGICAL_READS_PER_SESSION {integer | UNLIMITED | DEFAULT}]
[LOGICAL_READS_PER_CALL {integer | UNLIMITED | DEFAULT}]
[COMPOSITE_LIMIT {integer | UNLIMITED | DEFAULT}]
[PRIVATE_SGA {integer [K|M] | UNLIMITED | DEFAULT}]
CREATE ROLE role
[ !!under!!NOT IDENTIFIED
| IDENTIFIED {BY password | EXTERNALLY} ]
CREATE [PUBLIC] ROLLBACK SEGMENT rollback_segment
[TABLESPACE tablespace] [STORAGE storage_clause]
CREATE SCHEMA AUTHORIZATION schema
{ CREATE TABLE command | CREATE VIEW command | GRANT command } ...
CREATE SEQUENCE [schema.]sequence
[INCREMENT BY integer]
[START WITH integer]
[MAXVALUE integer | NOMAXVALUE]
[MINVALUE integer | !!under!!NOMINVALUE]
[CYCLE | NOCYCLE]
[CACHE integer | NOCACHE]
[ORDER | !!under!!NOORDER]
CREATE SNAPSHOT [schema.]snapshot
[ [PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause] | [CLUSTER cluster (column [, column]...) ]
[ USING INDEX [PCTFREE integer] [INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace] [STORAGE storage_clause] ]
[ REFRESH [FAST | COMPLETE | !!under!!FORCE] [START WITH date]
[NEXT date]]
AS subquery
CREATE SNAPSHOT LOG ON [schema.]table
[PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause]
CREATE [PUBLIC] SYNONYM [schema.]synonym
FOR [schema.]object[@dblink]
CREATE TABLE [schema.]table
( { column [datatype] [DEFAULT expr] [column_constraint] ...
| table_constraint}
[, { column [datatype] [DEFAULT expr] [column_constraint] ...
| table_constraint} ]...)
[ [PCTFREE integer] [PCTUSED integer]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace] [STORAGE storage_clause]
| CLUSTER cluster (column [, column]...) ]
[ ENABLE enable_clause | DISABLE disable_clause ] ...
[AS subquery]
CREATE TABLESPACE tablespace
DATAFILE filespec [, filespec] ...
[DEFAULT STORAGE storage_clause] [!!under!!ONLINE | OFFLINE]
CREATE [OR REPLACE] TRIGGER [schema.]trigger
{BEFORE | AFTER}
{DELETE | INSERT | UPDATE [OF column [, column] ...]}
[OR {DELETE | INSERT | UPDATE [OF column [, column] ...]}] ...
ON [schema.]table
[ [REFERENCING { OLD [AS] old [NEW [AS] new]
| NEW [AS] new [OLD [AS] old] } ]
FOR EACH ROW
[WHEN (condition)] ]
pl/sql_block
CREATE USER user
IDENTIFIED {BY password | EXTERNALLY}
[DEFAULT TABLESPACE tablespace]
[TEMPORARY TABLESPACE tablespace]
[QUOTA {integer [K|M] | UNLIMITED} ON tablespace] ...
[PROFILE profile]
CREATE [OR REPLACE] [FORCE | !!under!!NOFORCE] VIEW [schema.]view
[(alias [,alias]...)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
dblink database[.domain]...[@connection_qualifier]
DELETE [FROM] [schema.]{table | view}[@dblink] [alias] [WHERE condition]
DROP CLUSTER [schema.]cluster
[INCLUDING TABLES [CASCADE CONSTRAINTS] ]
DROP [PUBLIC] DATABASE LINK dblink
DROP FUNCTION [schema.]function
DROP INDEX [schema.]index
DROP PACKAGE [BODY] [schema.]package
DROP PROCEDURE [schema.]procedure
DROP PROFILE profile [CASCADE]
DROP ROLE role
DROP ROLLBACK SEGMENT rollback_segment
DROP SEQUENCE [schema.]sequence
DROP SNAPSHOT [schema.]snapshot
DROP SNAPSHOT LOG ON [schema.]table
DROP [PUBLIC] SYNONYM [schema.]synonym
DROP TABLE [schema.]table [CASCADE CONSTRAINTS]
DROP TABLESPACE tablespace [INCLUDING CONTENTS [CASCADE CONSTRAINTS]]
DROP TRIGGER [schema.]trigger
DROP USER user [CASCADE]
DROP VIEW [schema.]view
EXPLAIN PLAN [SET STATEMENT ID = 'text'] [INTO [schema.]table[@dblink]]
FOR statement
GRANT {system_priv | role} [, {system_priv | role}] ...
TO {user | role | PUBLIC} [, {user | role | PUBLIC}] ...
[WITH ADMIN OPTION]
GRANT {object_priv | ALL [PRIVILEGES]} [ (column [, column]...) ]
[, {object_priv | ALL [PRIVILEGES]} [ (column [, column] ...) ] ] ...
ON [schema.]object
TO {user | role | PUBLIC} [, {user | role | PUBLIC}] ...
[WITH GRANT OPTION]
INSERT INTO [schema.]{table | view}[@dblink] [ (column [, column] ...) ]
{VALUES (expr [, expr] ...) | subquery}
LOCK TABLE [schema.]{table | view}[@dblink]
[, [schema.]{table | view}[@dblink] ]...
IN lockmode MODE
[NOWAIT]
NOAUDIT {statement_opt | system_priv}
[, {statement_opt | system_priv} ] ...
[BY user [, user] ...]
[WHENEVER [NOT] SUCCESSFUL]
NOAUDIT object_opt [, object_opt] ...
ON [schema.]object
[WHENEVER [NOT] SUCCESSFUL]
RENAME old TO new
REVOKE {system_priv | role} [, {system_priv | role}] ...
FROM {user | role | PUBLIC}
[, {user | role | PUBLIC}] ...
REVOKE {object_priv | ALL [PRIVILEGES]}
[, {object_priv | ALL [PRIVILEGES]} ] ...
ON [schema.]object
FROM {user | role | PUBLIC} [, {user | role | PUBLIC}] ...
[CASCADE CONSTRAINTS]
ROLLBACK [WORK]
[ TO [SAVEPOINT] savepoint | FORCE 'text' ]
SAVEPOINT savepoint
SELECT [DISTINCT | !!under!!ALL] { *
| { [schema.]{table | view | snapshot}.*
| expr [ [AS] c_alias ] }
[, { [schema.]{table | view | snapshot}.*
| expr [ [AS] c_alias ] } ] ... }
FROM { (subquery)
| [schema.]{table | view | snapshot}[@dblink] } [t_alias]
[, { (subquery)
| [schema.]{table | view | snapshot}[@dblink] } [t_alias] ] ...
[WHERE condition ]
[ [START WITH condition] CONNECT BY condition]
[GROUP BY expr [, expr] ...] [HAVING condition]
[{UNION | UNION ALL | INTERSECT | MINUS} SELECT command ]
[ORDER BY {expr | c_alias | position} [!!under!!ASC | DESC]
[, {expr | c_alias | position}
[!!under!!ASC | DESC]] ...]
[FOR UPDATE [OF [[schema.]{table | view}.]column
[, [[schema.]{table | view}.]column] ...]
[NOWAIT] ]
SET ROLE { role [IDENTIFIED BY password]
[, role [IDENTIFIED BY password] ] ...
| ALL [EXCEPT role [, role] ...]
| NONE }
SET TRANSACTION
{ READ ONLY
| READ WRITE
| USE ROLLBACK SEGMENT rollback_segment }
TRUNCATE {TABLE [schema.]table | CLUSTER [schema.]cluster}
[ {!!under!!DROP | REUSE} STORAGE]
UPDATE [schema.]{table | view}[@dblink] [alias]
SET { (column [, column] ...) = (subquery)
| column = { expr | (subquery) } }
[, { (column [, column] ...) = (subquery)
| column = { expr | (subquery) } } ] ...
[WHERE condition]
11. Фразы предложений (команд) SQL Oracle7
ARCHIVE LOG [THREAD integer]
{ { SEQ integer | CHANGE integer | CURRENT | GROUP integer
| LOGFILE 'filename' | NEXT | ALL | START }
[TO 'location'] | STOP }
CONSTRAINT clause
Column constraint:
[CONSTRAINT constraint]
{ [NOT] NULL
| {UNIQUE | PRIMARY KEY}
| REFERENCES [schema.]table [(column)]
[ON DELETE CASCADE]
| CHECK (condition) }
{ [ USING INDEX [PCTFREE integer]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause] ]
[ EXCEPTIONS INTO [schema.]table
| DISABLE }
Table constraint:
[CONSTRAINT constraint]
{ {UNIQUE | PRIMARY KEY} (column [,column] ...)
| FOREIGN KEY (column [,column] ...)
REFERENCES [schema.]table [(column [,column] ...)]
[ON DELETE CASCADE]
| CHECK (condition) }
{ [ USING INDEX [PCTFREE integer]
[INITRANS integer] [MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause] ]
[ EXCEPTIONS INTO [schema.]table[@dblink]
| DISABLE }
DISABLE { { UNIQUE (column [, column] ...)
| PRIMARY KEY
| CONSTRAINT constraint }
[CASCADE]
| ALL TRIGGERS }
DROP { PRIMARY KEY
| UNIQUE (column [, column] ...)
| CONSTRAINT constraint }
[CASCADE]
ENABLE { {UNIQUE (column [, column] ...)
|PRIMARY KEY
|CONSTRAINT constraint}
[USING INDEX [INITRANS integer]
[MAXTRANS integer]
[TABLESPACE tablespace]
[STORAGE storage_clause]
[PCTFREE integer] ]
[EXCEPTIONS INTO [schema.]table ]
| ALL TRIGGERS }
Filespec: Data files:
'filename' [SIZE integer [K|M] ] [REUSE]
Redo log file groups:
{ 'filename'
| ('filename' [, 'filename'] ...)}
[SIZE integer [K|M] ] [REUSE]
RECOVER [AUTOMATIC] [FROM 'location']
{ [DATABASE] [ UNTIL CANCEL
| UNTIL TIME date
| UNTIL CHANGE integer
| USING BACKUP CONTROLFILE ]
| TABLESPACE tablespace [, tablespace] ...
| DATAFILE 'filename' [, 'filename'] ...
| LOGFILE 'filename'
| CONTINUE [DEFAULT]
| CANCEL }
STORAGE ( [INITIAL integer [K|M] ]
[NEXT integer [K|M] ]
[PCTINCREASE integer]
[MINEXTENTS integer]
[MAXEXTENTS integer]
[OPTIMAL {integer [K|M] | NULL}]
[FREELIST GROUPS integer]
[FREELISTS integer] )
WHERE [NOT] condition [{AND | OR} [NOT] condition ] ...
12. Язык PL/SQL - процедурные расширения языка SQL
12.1. Основные конструкции языка PL/SQL
PL/SQL - это блочно-структурированный язык. Структура блока имеет вид:
[ DECLARE
-- описание переменных, констант и пользовательских типов данных ]
BEGIN
-- тело основной программы, в которую могут вкладываться другие
-- блоки (в них также можно вкладывать блоки и т.д.)
[ EXCEPTION
-- драйверы для обработки исключительных ситуаций в программе ]
END;
Программы PL/SQL могут быть неименовынными (анонимными блоками), но чаще
всего используются именованные программы: процедуры, функции, пакеты и триггера
(см. п. 12.7).
12.2. Типы данных, переменные, константы и выражения
12.2.1. Типы данных, доступные в PL/SQL
Кроме типов данных Oracle7 (см. п. 5), PL/SQL поддерживает несколько
дополнительных типов данных и позволяет использовать в своих конструкциях
некоторые основные типы с большим диапазоном.
Тип данных Описание
-------------- ---------------------------------------------------------------
BINARY_INTEGER Этот тип данных и его подтипы NATURAL и POSITIVE применяются для
создания переменных и констант, которые хранят число со знаком.
Двоичные целые числа могут принимать значения в диапазоне от -2
в 31 степени до 2 в 31 степени минус 1.
BOOLEAN Принимается для создания переменных и констант, в которых
хранятся логические значения TRUE и FALSE.
CHAR Есть подтипы CHARACTER и STRING. Максимальный размер 32767.
NUMBER Есть подтипы DEC, DECIMAL, DOUBLE, PRECISION, FLOAT, INT,
INTEGER, NUMERIC, REAL и SMALLINT.
RECORD Используется для создания пользовательских типов записей базы
данных.TABLE Служит для создания табличных типов данных PL/SQL.
VARCHAR2 Есть подтип VARCHAR. Максимальный размер 32767.
col%TYPE Используется для определения типа данных столбца или переменной
по типу данных другого столбца или переменной, к имени которого
или которой (col) приписан суффикс %TYPE.
tab%ROWTYPE Используется для определения типа данных записи по типу данных
столбцов таблицы, к имени которой (tab) приписан суффикс
%ROWTYPE.
Рассмотрим подробнее типы данных TABLE и RECORD, позволяющие создавать
одномерные массивы и записи, широко используемые в программах PL/SQL.
Таблица PL/SQL - это одномерный массив с неограниченным числом строк. Для
объявления этого массива (таблицы PL/SQL или TABLE) необходимо сначала
определить его тип данных.
Для описания типа данных TABLE используется синтаксис:
TYPE type_name IS TABLE OF { column_type | variable%TYPE |
table.column%TYPE } [NOT NULL] INDEX BY BINARY_INTEGER;
где "type_name" - спецификатор типа, используемый в последующих объявлениях
таблиц PL/SQL, и "column_type" - любой из скалярных типов данных: CHAR, DATE или
NUMBER. С помощью атрибута %TYPE можно установить "type_name" соответствующим
типу данных какой-либо переменной (variable) или столбца (table.column).
Имя (например, name_plsql_table), которое описывается табличным типом
данных, называется таблицей PL/SQL. Это описание, размещаемое в разделе DECLARE,
имеет вид:
name_plsql_table type_name;
Ссылки на строки таблицы PL/SQL осуществляются аналогично ссылкам на элементы
одномерного массива:
name_plsql_table(index) ,
где index принадлежит типу BINARY_INTEGER. Например, для ссылки на третью строку
в таблице PL/SQL "ename_tab" следует написать: ename_tab(3).
Для присвоения значения конкретной строке таблицы PL/SQL используется
синтаксис:
name_plsql_table(index) := expr;
Для ввода в таблицу PL/SQL значений из какого-либо столбца базовой таблицы
или представления, а также для выборки значений из таблицы PL/SQL, необходимо
использовать цикл. (Примеры таких операций приведены в п. 12.4.)
Record PL/SQL - это совокупность полей, каждое из которых должно иметь
уникальное имя (в пределах записи). Эти поля могут принадлежать различным
типам данных.
Если создаваемая запись (sotr) соответствует описанию столбцов какой-либо
базовой таблицы (например, kadry), то ее объявление можно осуществить в разделе
DECLARE с помощью атрибута
%ROWTYPE:sotr kadry%ROWTYPE;
В противном случае для объявления записи необходимо сначала определить ее
тип данных. Для описания типа данных RECORD используется синтаксис:
TYPE type_name IS RECORD
( field_name1 {field_type | variable%TYPE | table.column%TYPE
| table%ROWTYPE} [NOT NULL],
field_name2 {field_type | variable%TYPE | table.column%TYPE
| table%ROWTYPE} [NOT NULL],
...);
где "type_name" - спецификатор типа, используемый в последующих объявлениях
записей PL/SQL, и "field_type" - любой тип данных. С помощью атрибута %TYPE
можно установить "type_name" соответствующим типу данных какой-либо переменной
(variable) или столбца (table.column). Атрибут %ROWTYPE позволяет определить
поле как запись, соответствующую описанию столбцов какой-либо базовой таблицы.
При объявлении типа записи можно присвоить ее полям некоторые значения. Если
же для поля вводится ограничение NOT NULL (для предотвращения назначения пустых значений), то этому полю надо обязательно присвоить значение. Например:TYPE SotrRecTyp IS RECORD (nomer NUMBER(4) NOT NULL := 1001,
familiy CHAR(20), dolgnost CHAR(14), otdel NUMBER(3) := 102);
Объявление создаваемой записи (например, name_plsql_record) производится в
разделе DECLARE и имеет вид:
name_plsql_record type_name;
Ссылки на отдельные поля записи осуществляются так:
name_plsql_record.field_name;
Для присвоения значения конкретному полю записи используется синтаксис:
name_plsql_record.field_name := expr;
Примеры использования записей в программах PL/SQL приведены ниже.
Для ввода в таблицу PL/SQL значений из какого-либо столбца базовой таблицы
или представления, а также для выборки значений из таблицы PL/SQL, необходимо
использовать цикл. (Примеры таких операций приведены в п. 12.4.)
12.2.4. Переменные, константы и выражения
В программах PL/SQL могут использоваться переменные и константы, описываемые
в разделе DECLARE с помощью конструкции вида:
variable_name [CONSTANT] type_name [NOT NULL] [ { := | DEFAULT } expr ]
Например
birthdate DATE;
emp_count SMALLINT := 0;
emp_count SMALLINT DEFAULT 0;
acct_id VARCHAR2(5) NOT NULL := 'AP001';
pi CONSTANT REAL := 3.14159;
area REAL := pi * radius**2;
valid_id BOOLEAN;
valid_id VARCHAR2(5); -- недопустимое вторичное описание valid_id
i, j, k SMALLINT; -- нельзя описывать список; надо:
-- i SMALLINT; j SMALLINT; k SMALLINT;
credit REAL(7,2);
debit credit%TYPE; -- тип данных аналогичный типу данных "credit"
Синтаксис выражения описан в п. 4.3.
12.3. Связь объектов PL/SQL с таблицами базы данных
Чтобы программа PL/SQL могла работать с информацией, содержащейся в базах
данных, необходимо организовать обмен между значениями столбцов таблиц баз
данных и переменными PL/SQL.
Известно, что для выбора информации из таблиц используется SQL предложение
SELECT. При его выполнении Oracle создает специальную рабочую область,
содержащую информацию о самом SELECT, данные, которые требуются для его
выполнения (например, результаты подзапросов), и, наконец, окончательный
результат выполнения SELECT. PL/SQL имеет несколько механизмов доступа к
этой рабочей области. Одним из них является курсор, с помощью которого можно
присвоить имя этой рабочей области и манипулировать содержащейся в ней
информацией, последовательно выбирая строки результата и пересылая значения
столбцов текущей строки в переменные PL/SQL. Существуют и другие механизмы,
не требующее создания явного курсора.
Курсор - это средство языка SQL, позволяющее с помощью команд OPEN, FETCH и
CLOSE получить построчный доступ к результату запроса к базе данных. (Будем
также называть курсором и сам набор строк, полученный в результате выполнения
запроса.)
Для использования курсора его надо сначала объявить, т.е. дать ему имя и
указать (с помощью предложения SELECT), какие столбцы и строки базовых таблиц
должны быть помещены в набор строк, названный этим именем. Команда OPEN
инициализирует получение указанного набора и установку перед первой его строкой
указателя текущей строки. Команда FETCH служит для установки указателя текущей
строки на следующую запись (первый раз на строку с номером 1) и выборки из
текущей строки курсора значений указанных столбцов с пересылкой их в переменные
PL/SQL. (Выполнением FETCH в цикле можно последовательно выбрать информацию из
всех строк курсора.) Наконец, команда CLOSE позволяет закрыть (удалить из
памяти) набор строк (при этом описание курсора сохраняется и его можно снова
открыть командой OPEN).
Существует модификация ("Курсор в цикле FOR"), позволяющая организовать
последовательный выбор строк объявленного курсора без явного использования
команд OPEN, FETCH и CLOSE.
12.3.1.1. Объявление курсора
Перед работой с курсором его следует объявить в разделе DECLARE или другом
допустимом разделе, используя синтаксис:
CURSOR cursor_name [ (parameter [, parameter, ... ] ) ] IS SELECT ... ,
где
curs
or_name - имя курсора;SELECT ... - предложение SELECT, определяющее строки курсора;
parametr - имеет следующий синтаксис:
variable_name [IN] type_name [ { := | DEFAULT } value ] ,
а type_name - любой тип (подтип) данных PL/SQL без указания ограничений
(например, длины символьных значений).
Формальные параметры курсора используются только для передачи значений в
WHERE фразу предложения SELECT с целью отбора нужных строк запроса. Передача
таких значений производится во время открытия курсора командой OPEN. Если
значения формальных параметров отсутствуют в команде OPEN и не заданы по
умолчанию (:= value или DEFAULT value), то выдается ошибка. При наличии тех и
других используются параметры из команды OPEN.
В следующем примере использованы оба способа задания значений по умолчанию
параметрам курсора:
DECLARE
CURSOR s1 (otd INTEGER := 102, grup VARCHAR2 DEFAULT 'Преподаватели',
tdat DATE := '1.1.1996') IS
SELECT (TO_CHAR(razr)||' '||imya_dolg) razr_dolg, stavka
FROM shtat x, dolgnosti y, grup_dolg z
WHERE x.dolgn = y.dolgn AND y.grup_dolg = z.grup_dolg AND otdel = otd
AND tdat BETWEEN nachalo AND konec AND imya_grup_dolg = grup
ORDER BY razr_dolg DESC;
Кроме того, в нем выражению "(TO_CHAR(razr)||' '||imya_dolg)" дан псевдоним
"razr_dolg", использованный во фразе ORDER BY. Oracle рекомендует создавать псевдонимы для всех выражений фразы SELECT с целью ссылки на них при работе с курсором.12.3.1.2. Открытие курсора (OPEN)
Команда OPEN имеет следующий синтаксис
OPEN cursor_name [ (value [,value]...) ];
где список значений ("value") используется для передачи параметров курсора и
должен по числу и типу данных совпадать с описанием этих параметров.
Команда выполняет объявленный в курсоре SELECT ... , используя (если есть
параметры) передаваемые из OPEN значения или значения, указанные при объявлении
курсора, создавая набор строк и устанавливая указатель текущей строки перед
первой из них. Так, по команде
OPEN s1;
будет создан набор:
razr_dolg stavka
Указатель текущей строки ---> ------------------------ ------
17 Профессор 1.75
16 Профессор 3.
15 Доцент 9.7514 Доцент 4.
13 Старший преподаватель 8.75
11 Ассистент 1.
где использовались значения параметров, заданные при описании, а по команде:
OPEN s1 (102,'Специалисты','1.1.1996');
будет создан другой набор:
razr_dolg stavka
Указатель текущей строки ---> ------------------------ ------
13 Ведущий программист 1.13 Ведущий электроник 2.
11 Электроник 1 категории 1.5
10 Программист 2 категории 3.5
8 Инженер 2 категории 2.4 Лаборант 3.
12.3.1.3. Выборка строк из курсора (FETCH)
Команда FETCH, используемая для продвижения на один шаг указателя текущей
строки курсора и пересылки ее значений в переменные или запись, имеет следующий
синтаксис:
FETCH cursor_name INTO {variable_name1[,variable_name2]...} | record_name ;
Для каждого значения столбца, возвращенного запросом, в списке INTO должна
иметься переменная или поле записи соответствующего типа данных. Такие
переменные или записи должны быть заранее описаны в декларативной части блока
PL/SQL. Например
CREATE PROCEDURE pr_shtat IS
CURSOR s1 (otd INTEGER := 102, grup VARCHAR2 DEFAULT 'Преподаватели',
tdat DATE := '1.1.1996') IS
SELECT (TO_CHAR(razr)||' '||imya_dolg) razr_dolg, stavka
FROM shtat x, dolgnosti y, grup_dolg z
WHERE x.dolgn = y.dolgn AND y.grup_dolg = z.grup_dolg AND otdel = otd
AND tdat BETWEEN nachalo AND konec AND imya_grup_dolg = grup
ORDER BY razr DESC;
sh_raz VARCHAR2(45); -- переменная для хранения значения razr_dolg
sh_stav shtat.stavka%TYPE; -- переменная для хранения значения stavka
raz VARCHAR(500); -- переменная, в которой будет последовательно
-- накапливаться текст "разряд-должность"BEGIN
OPEN s1;
LOOP
FETCH s1 INTO sh_raz,sh_stav;
EXIT WHEN s1%NOTFOUND; -- выход при отсутствии возвращаемой строки
-- (см. п. 12.3.1.6)
raz := raz||sh_raz||';';
...
END LOOP;
CLOSE s1;
END pr_shtat;
Внутри цикла можно использовать значения переменных sh_raz и sh_stav, которые
после открытия курсора равны "17 Профессор" и "1.75", после первого прохождения
цикла - "16 Профессор" и "3.", после второго - "15 Доцент" и "9.75" и т.д.
При выборке значений текущей строки в запись, например, с именем ShRec надо
немного изменить как описание, так и тело блока процедуры:
...
ORDER BY razr DESC;
TYPE ShRecTyp IS RECORD (raz_dol VARCHAR(45
), -- описание типа данныхstav shtat.stavka%TYPE); -- записи ShRec
ShRec ShRecTyp; -- объявление записи ShRec
raz VARCHAR(500); -- переменная, в которой будет последовательно
-- накапливаться текст "разряд-должность"
BEGIN
OPEN s1;
LOOP
FETCH s1 INTO ShRec;
EXIT WHEN s1%NOTFOUND; -- выход при отсутствии возвращаемой строки
raz := raz||ShRec.raz_dol||';';
...
Теперь значения, получаемые ранее из sh_raz и sh_stav, можно получать из
полей ShRec.raz_dol и ShRec.stav записи ShRec.
Целесообразность использования записей возрастает с увеличением количества
ее полей или возможности создания описания по типу уже существующей записи с
помощью атрибута %ROWTYPE.
Наконец, если при выполнении цикла осуществлен переход за последнюю строку
набора, то значения переменных FETCH-списка будут неопределены.
12.3.1.4. Закрытие курсора (CLOSE)
Команда CLOSE используется для освобождения всех ресурсов, которые
поддерживались открытым курсором (при этом описание курсора сохраняется и его
можно снова открыть командой OPEN). Синтаксис команды CLOSE имеет вид:
CLOSE cursor_name;
12.3.1.5. Использование курсора в цикле FOR
В большинстве ситуаций, которые требуют явного курсора, текст программы может
быть упрощен при использовании "курсора в цикле FOR", заменяющего команды OPEN,
FETCH и CLOSE. Курсор в цикле FOR:
- неявно объявляет индекс цикла записью, поля которой соответствуют столбцам
(псевдонимам) предложения SELECT ... из описания курсора;
- передает параметры курсора (если они есть) и открывает курсор;
- выбирает в цикле строки из полученного набора в индекс цикла (поля записи);
- закрывает курсор после обработки всех строк набора или досрочному выходу
из него с помощью команд EXIT или GOTO.
Синтаксис курсора в цикле FOR имеет вид:
FOR var_rec_name IN cursor_name [ (value [,value]...) ] LOOP
ТЕЛО ЦИКЛА
END LOOP;
где - var_rec_name индекс цикла, в котором при первом прохождении цикла хранится
первая строка набора, при втором прохождении цикла - вторая строка и т.д.;
- список значений ("value") используется для передачи параметров курсора
(он заменяет в данном случае список из команды OPEN);
- ТЕЛО ЦИКЛА содержит нужные строки повторяющейся части программы, в которых
используются переменные с именами var_rec_name.column_name, а column_name
имя столбца из перечня столбцов предложения SELECT в описании курсора.
Например,
DROP PROCEDURE pr_shtat;
CREATE PROCEDURE pr_shtat IS
CURSOR s1 (otd INTEGER := 102, grup VARCHAR2 DEFAULT 'Преподаватели',
tdat DATE := '1.1.1996') IS
SELECT otdel, (TO_CHAR(razr)||' '||imya_dolg) razr_dolg, stavka
FROM shtat x, dolgnosti y, grup_dolg z
WHERE x.dolgn = y.dolgn AND y.grup_dolg = z.grup_dolg AND otdel = otd
AND tdat BETWEEN nachalo AND konec AND imya_grup_dolg = grup
ORDER BY razr DESC;
raz VARCHAR(500); --
переменная, в которой будет последовательно-- накапливаться текст "разряд-должность"
BEGIN
FOR s1_rec IN s1 (102,'Специалисты','1.6.1996') LOOP
raz := raz||s1_rec.razr_dolg||';';
...
END LOOP;
END pr_shtat;
12.3.1.6. Атрибуты явного курсораДля анализа состояния курсора используются специальные переменные, имена
которых составляются из имени курсора и суффиксов %FOUND, %NOTFOUND, %ROWCOUNT
и %ISOPEN, называемых атрибутами курсора. Если курсор назван "cursor_name", то
эти переменные имеют имена:
cursor_name%NOTFOUND, cursor_nane%FOUND,
cursor_nane%ROWCOUNT и cursor_nane%ISOPEN.
Значения таких переменных анализируются при выполнении программы с помощью
различных операторов управления (IF...THEN, EXIT WHEN и т.п.), которые изменяют
(при необходимости) ход выполнения программы. Следует отметить, что ссылка на
эти переменные до открытия курсора приводит к появлению сообщения INVALID_CURSOR.
Переменная с атрибутом %ISOPEN позволяет определить, открыт ли курсор. Если
он открыт то эта переменная возвращает TRUE, иначе - FALSE. Например:
IF NOT s1%ISOPEN THEN -- курсор не открыт ?
OPEN s1; -- открыть курсор !
IF END;
FETCH ...
Переменные с %NOTFOUND и %FOUND атрибутами показывают состояние текущей
позиции курсора (перед первой выборкой строки курсора обе переменных имеют
значение NULL). Переменная с %NOTFOUND принимает значение FALSE тогда, когда
выборка возвратила строку (при этом переменная с %FOUND принимает значение
TRUE). Если же в результате выборки строка не возвращается, то переменные с
%NOTFOUND и %FOUND принимают значения TRUE и FALSE, соответственно. Пример
использования %NOTFOUND был рассмотрен в п. 12.3.1.3.
Переменная с атрибутом %ROWCOUNT содержит количество строк, выбранных из
курсора на текущий момент (при открытии курсора эта переменная содержит ноль).
В следующем примере переменная s1%ROWCOUNT ограничивает выборку из курсора s1
десятью строками:
LOOP
FETCH s1 INTO sh_raz,sh_stav;
IF s1%ROWCOUNT > 10 THEN
...
END IF;
...
END LOOP;
12.3.1.7. Изменение или удаление текущей строки курсора
Существует два предложения, позволяющие изменить или удалить ту строку
таблицы базы данных, на которую позиционирована текущая строка курсора:
UPDATE [schema.]{table | view}[@dblink] [alias]
SET { (column [, column] ...) = (subquery)
| column = { expr | (subquery) } }
[, { (column [, column] ...) = (subquery)
| column = { expr | (subquery) } } ] ...
WHERE CURRENT OF cursor_name;
DELETE [FROM] [schema.]{table | view}[@dblink] [alias]
WHERE CURRENT OF cursor_name;
Для этого необходимо, чтобы при объявлении курсора предложение SELECT ...
содержало фразу
FOR UPDATE OF [[schema.]{table | view}.]column
[, [[schema.]{table | view}.]column ] ... ;
в которой следует привести список обновляемых столбцов.
12.3.2. Неявный курсор (SQL курсор)
Для всех команд языка SQL, не связанных с объявлением курсора ("явным
курсором"), PL/SQL открывает курсор ("неявный курсор"), на который можно
ссылаться по курсорному имени SQL%. При работе с таким курсором нельзя
использовать команды OPEN, FETCH и CLOSE, но можно использовать атрибуты
курсора, чтобы получить информацию о текущем его состоянии.
12.3.2.1. SELECT ... INTO
В тех случаях, когда программе необходимо иметь значения столбцов из одной
строки таблицы, можно воспользоваться предложением SELECT ... INTO, формат
которого имеет вид:
SELECT [DISTINCT | !!under!!ALL]
{ [schema.]{table | view | snapshot}.expr [c_alias] }
[, { [schema.]{table | view | snapshot}.expr [c_alias] } ] ... }
INTO { variable_name [, variable_name ] ... } | record_name
FROM table_list [WHERE condition]
[GROUP BY expr [, expr] ...] [HAVING condition]
[ {UNION | UNION ALL | INTERSECT | MINUS} SELECT command]
[ORDER BY {expr | c_alias | position}
[!!under!!ASC | DESC] [, {expr | c_alias | position}
[!!under!!ASC | DESC]] ]...
[FOR UPDATE [OF [[schema.]{table | view}.]column
[, [[schema.]{table | view}.]column] ...]
[NOWAIT] ]
Практически это обычный SELECT, выполняющий присвоение выбираемых значений
столбцов переменным, перечисленным во фразе INTO. Однако такое присвоение
происходит только в том случае, если "WHERE condition" обеспечивает возвращение
по запросу лишь одной строки и переменные заранее описаны в декларативной
части блока PL/SQL.
12.3.2.2. UPDATE, DELETE и INSERT
Эти предложения отличаются от аналогичных предложений интерактивного SQL
лишь тем, что в их выражениях (expr) могут использоваться переменные PL/SQL.
12.3.2.3. Атрибуты неявного курсора (SQL курсора)
Для анализа результата выполнения предложений SELECT...INTO, INSERT, UPD
ATEи DELETE используются три переменные: SQL%NOTFOUND, SQL%FOUND и SQL%ROWCOUNT
(Oracle закрывает курсор SQL автоматически после выполнения SQL предложения,
что делает бессмысленным использование переменной SQL%ISOPEN, так как ее
значение всегда равно FAL
SE).Перед выполнением предложений SELECT...INTO, INSERT, UPDATE и DELETE
переменные SQL%NOTFOUND и SQL%FOUND имеют значение NULL. Переменная SQL%NOTFOUND
принимает значение TRUE, если INSERT, UPDATE и DELETE не произвели изменений
таблиц базы данных или SELECT...INTO не возвратил строк (при этом переменная
SQL%FOUND принимает значение FALSE). В противном случае переменная SQL%NOTFOUND
принимает значение FALSE, а переменная SQL%FOUND - TRUE
Вот один из примеров использования SQL%NOTFOUND для добавления новой строки
в таблицу temp при сбое модификации:
UPDATE shtat SET stavka = stavka + 1 WHERE dolgn = 'доцент' AND razr = 15;
IF SQL%NOTFOUND THEN -- изменение не выполнено
INSERT INTO temp VALUES (...);
END IF;
12.4. Операторы управления выполнением программы
12.4.1. Операторы условного перехода (IF ...)
Существует три модификации оператора условного перехода:
IF-THEN | IF-THEN-ELSIF
------- | -------------
IF условие THEN | IF условие1 THEN
последовательность команд; | 1-я последовательность команд;
END IF; | ELSIF условие2 THEN
| 2-я последовательность команд;
IF-THEN-ELSE | ...
------------ | ELSIF условиеN THEN
IF условие THEN | N-я последовательность команд;
1-я последовательность команд; | [ ELSE
ELSE
| N+1-я последовательность команд; ]2-я последовательность команд; | END IF;
END IF; |
Синтаксис условий приведен в п. 4.4. Во всех модификациях если "условие" или
"условие1" истинно (TRUE), то выполняется "последовательность команд" или
"1-я последовательность команд" и управление передается на первый оператор
после END IF. Если же оно ложно (FALSE), то:
- в модификации IF-THEN управление передается на первый оператор после END
IF;- в модификации IF-THEN-ELSE выполняется 2-я последовательность команд и
управление передается на первый оператор после END IF;
- в модификации IF-THEN-ELSIF проверяется условие 2; если оно истинно, то
выполняется 2-я последовательность команд и управление передается на первый
оператор после END IF; если условия 1 и 2 ложны, а условие 3 истинно, то
выполняется 3-я последовательность команд и управление передается на первый
оператор после END IF; наконец, если условия 1, 2, ..., N ложны, то
выполняется N+1-я последовательность команд и управление передается на первый
оператор после END IF.
Все это справедливо, если внутри последовательности команд нет операторов,
осуществляющих переход за пределы этой последовательности.
12.4.2. Метки и оператор безусловного перехода (GOTO)
В любом месте программы может быть поставлена метка, имеющая синтаксис:
<<имя_метки>>
Оператор GOTO позволяет осуществить безусловный переход к метке, имя которой
должно быть уникальным внутри программы или блока PL/SQL. Например, управление
передается вниз к помеченному оператору:
BEGIN
...
GOTO insert_row;
...
<>
INSERT INTO shtat VALUES ...
END;
В следующем примере управление передается вверх к помеченной
последовательности операторов:BEGIN
...
<>
BEGIN
UPDATE shtat SET ...
...
END;
...
GOTO update_row;
...
END;
Следует отметить, что использование GOTO (особенно в тех случаях, когда метка
предшествует оператору GOTO) может привести к сложным, нераспознаваемым кодам
ошибок, которые трудно обрабатывать. Поэтому реже используйте GOTO, тем более
что этот оператор нельзя использовать для выполнения перехода:
- в IF-блок, LOOP-блок или в другой блок, не включающий текущий;
- из одного предложения IF-оператора к другому;
- из внешнего блока в SUB-блок;
- из обработчика особых ситуаций в текущий блок.
12.4.3. Операторы цикла (LOOP, WHILE...LOOP и FOR...LOOP)
Циклы служат для повторяемого выполнения последовательности команд. В PL/SQL
используются три модификации операторов цикла: LOOP, WHILE...LOOP и FOR...LOOP.
Цикл LOOP имеет следующий синтаксис:
LOOP
последовательность команд;
END LOOP;
и приводит к бесконечному повторению последовательности команд, если внутри
нее нет команд EXIT (выход из цикла), RAISE (вызов обработчика исключительных
ситуаций) или GOTO (безусловный переход). Например,
LOOP
последовательность команд;
IF условие THEN EXIT;
END LOOP;
приведет к выходу из цикла после выполнения последовательности команд, как
только условие станет истинным.
Цикл WHILE предназначен для повторения последовательности команд, пока
условие остается истинным:
WHILE условие LOOP
последовательность команд;
END LOOP;
Наиболее распространен цикл FOR, имеющий следующий синтаксис:
FOR индекс IN [REVERSE] нижняя_граница..верхняя_граница LOOP
последовательность команд;
END LOOP;
Здесь индекс (счетчик циклов) изменяется от нижней до верхней границы с
шагом 1, а при использовании "REVERSE" - от верхней до нижней границы с шагом
-1. Например,
FOR i IN 1..3 LOOP -- для i = 1, 2, 3
последовательность команд; -- цикл выполняется 3 раза
END LOOP;
FOR i IN REVERSE 1..3 LOOP -- для i = 3, 2, 1
последовательность команд; -- цикл выполняется 3 раза
END LOOP;
Отметим, что в последнем случае пределы диапазона указываются в возрастающем,
а не убывающем порядке.
Если нижняя граница равна верхней, последовательность выполняется один раз.
Если нижняя граница больше верхней, последовательность не выполняется, и
управление переходит к следующему за циклом оператору.
Пределы диапазона цикла могут быть литералами, переменными или выражениями,
но должны быть целыми числами. Например, допустимы следующие диапазоны:
j IN -5..5
k IN REVERSE first..last
step IN 0..TRUNC(high/low) * 2
code IN ASCII('A')..ASCII('J')
Объявлять индекс не нужно - он объявлен неявно как локальная переменная типа
integer.
PL/SQL позволяет определять диапазон цикла динамически во время выполнения.
Например:
SELECT COUNT(otdel) INTO shtat_count FROM shtat;
FOR i IN 1..shtat_count LOOP
...
END LOOP;
Значение "shtat_count" - неизвестно во времени компиляции; предложение SELECT
определяет это значение во время выполнения.
Индекс может использоваться в выражениях внутри цикла, но не может изменяться.
Например:
FOR ctr IN 1..10 LOOP
...
IF NOT finished THEN
INSERT INTO ... VALUES (ctr, ...); -- правильно
factor := ctr * 2; -- правильно
...
ELSE
ctr := 10; -- неправильно
END IF;
END LOOP;
Индекс определен только внутри цикла и на него нельзя ссылаться снаружи
цикла. После выполнения цикла индекс неопределен. Например:
FOR ctr IN 1..10 LOOP
...
END LOOP;
sum := ctr - 1; -- неверно
Подобно PL/SQL блокам, циклы могут быть помечены. Метка устанавливается в
начале оператора LOOP, следующим образом:
<>
LOOP
последовательность команд;
END LOOP;
Имя метки может также появляться в конце утверждения LOOP как в примере:
<>
LOOP
...
END LOOP my_loop;
Помеченные циклы используются для улучшения чтения программы (разборчивости).
С любой формой утверждения EXIT можно завершать не только текущий цикл, но и
любой внешний цикл. Для этого маркируйте внешний цикл, который надо завершить,
и используйте метку в утверждении EXIT, следующим образом:
<>
LOOP
...
LOOP
...
EXIT outer WHEN ... -- завершаются оба цикла
END LOOP;
...
END LOOP outer;
Если требуется преждевременно выйти из вложенного цикла FOR, маркируйтецикл и используйте метку в утверждении EXIT. Например:
<>
FOR i IN 1..5 LOOP
...
FOR j IN 1..10 LOOP
FETCH s1 INTO ShRec;
EXIT outer WHE
N s1%NOTFOUND; -- завершаются оба цикла...
END LOOP;
END LOOP outer;
-- управление передается сюда
12.4.4. Операторы EXIT, EXIT-WHEN и NULL
EXIT используется для завершения цикла, когда дальнейшая обработка
нежелательна или невозможна. Внутри цикла можно помещать один или большее
количество операторов EXIT. Имеются две формы EXIT: EXIT и EXIT-WHEN.
По оператору EXIT цикл завершается немедленно и управление переходит к
следующему за END LOOP оператору. Например:
LOOP
...
IF ... THEN
...
EXIT; -- цикл завершается немедленно
END IF;
END LOOP;
-- управление переходит сюда
По оператору EXIT-WHEN цикл завершиться только в том случае, когда становится
истинным условие в предложении WHEN. Например:
LOOP
FETCH s1 INTO ...
EXIT WHEN s1%NOTFOUND; -- конец цикла, если условие верно
...
END LOOP;
CLOSE s1;
Оператор EXIT-WHEN позволяет завершать цикл преждевременно. Например,
следующий цикл обычно выполняется десять раз, но как только не находится
значение s1, цикл завершается независимо от того сколько раз цикл выполнился.
FOR j IN 1..10 LOOP
FETCH s1 INTO ShRec;
EXIT WHEN s1%NOTFOUND; -- выход при отсутствии возвращаемой строки
...
END LOOP;
NULL - пустой оператор; он передает управление к следующему за ним оператору.
Однако, к нему может передаваться управление и его наличие часто улучшает
читаемость программы. Он также полезен для создания фиктивных подпрограмм для
резервирования областей определения функций и процедур при отладке программ.
Нельзя создать приложение, которое будет безошибочно работать в любых
ситуациях: возможны аппаратные сбои, невыявленные ошибки приложения и ошибки
из-за некорректных действий пользователей приложения (клиентов). Если при этом
программная ошибка произошла в блоке PL/SQL, вложенном в другой блок, а тот,
в свою очередь, вложен в третий блок и т.д., то она может дойти до клиентского
приложения. Чтобы устранить возможную отмену большого объема ранее выполненных
операций и трафик из-за возвращаемых клиенту ошибок, чтобы посылать клиенту
точные сообщения о причине ошибки и способе ее устранения (если она все же
дошла до клиента), разработчики приложения должны предусматривать возможные
программные ошибки и создавать процедуры, адекватно реагирующие на них.
В PL/SQL предусмотрен механизмы перехвата и обработки ошибок, возникающих
при выполнении программы. Эти механизмы называются исключительными ситуациями.
Когда программа обнаруживает заданное условие ошибки, то вызывается
соответствующая исключительная ситуация. Обработки исключительных ситуаций в
программе производится в разделе EXCEPTION (см. п. 12.1).
При обнаружении исключительной ситуации, обработка основного тела программы
останавливается и управление передается соответствующему обработчику
исключительной ситуации, который определяет дальнейшие действия.
В PL/SQL используются следующие типы исключительных ситуаций:
- встроенные исключительные ситуации;
- исключительные ситуации, определяемые пользователем;
- обработчик OTHERS.
12.5.1. Встроенные исключительные ситуации
Oracle включает четырнадцать встроенных исключительных ситуаций,
соответствующих типовым ошибкам, приведенным в следующей таблице:
ОшибкаИсключительная ситуация ORACLE Описание
---------------------- --------- ---------------------------------------------
CURSOR_ALREADY_OPEN ORA-06511 Попытка открытия уже открытого курсора
DUP_VA
L_ON_INDEX ORA-00001 Попытка вставить дубликат значения дляуникального индекса
INVALID_CURSOR ORA-01001 Попытка выполнения запрещенной операции с кур-
сором (например, закрытие неоткрытого курсора)
INVALID_NUMBER ORA-01722 Отказ преобразования строки символов в число
LOGIN_DENIED ORA-01017 Неправильное имя пользователь/пароль
NO_DATA_FOUND ORA-01403 Предложение SELECT...INTO возвращает ноль строк
NOT_
LOGGED_ON ORA-01012 Нет подключения к Oracle7PROGRAM_ERROR ORA-06501 Внутренняя ошибка PL/SQL
STORAGE_ERROR ORA-06500 Пакет PL/SQL вышел из пределов памяти или если
память разрушена
TIMEOUT_ON_RE
SOURCE ORA-00051 Истекло время ожидания ресурса Oracle7TOO_MANY_ROWS ORA-01422 Предложение SELECT...INTO возвращает более
одной строки
TRANSACTION_BACKED_OUT ORA-00061 Удаленный сервер отменил транзакцию
VALUE_
ERROR ORA-06502 Арифметическая ошибка, ошибка преобразования,усечения или ограничения
ZERO_DIVIDE ORA-01476 Попытка деления на ноль
Если в раздел EXCEPTION программы (блока) включена фраза
WHE
N имя_исключения THENтекст_обработчика_исключения;
с именем какого-либо встроенного исключения и возникла соответствующая ошибка,
то вместо прекращения исполнения программы и выдачи типового сообщения об
ошибке, будет исполняться созданный пользователем текст обработчика исключения.
Такой обработчик может, например, выяснить ситуацию, при которой произошло
деление на ноль, и выдать правдоподобный результат операции деления или
прервать исполнение программы и дать сообщение об изменении каких-либо данных.
В последнем случае это может быть не типовое сообщение "Вы пытаетесь делить на
ноль", а любое подготовленное пользователем сообщение, например, инструкцию
длиной до 2048 символов.
Для выдачи сообщения об ошибке, обеспечения возврата в среду, из которой
вызывалась текущая программа (блок) и отмены всех действий, выполненных в
текущей транзакции, целесообразно использовать процедуру
RAISE_APPLICATION_ERROR(errnum,errtext);
где errnum - отрицательное целое число в диапазоне -20000 .. -20999 и err
text- символьная строка длиной до 2048 символов.
В приведенном ниже триггере "shtins" использованы два типа встроенных
исключительных ситуаций: NO_DATA_FOUND и TOO_MANY_ROWS.
DROP TRIGGER shtins;
CREATE TRIGGER shtins
BEFORE INSERT ON SHTAT
FOR EACH ROW
DECLARE
nach DATE;
kon DATE;
str NUMBER;
minraz NUMBER;
maxraz NUMBER;
nach_kon EXCEPTION;
err_str EXCEPTION;
nach_nach EXCEPTION;
err_razr EXCEPTION;
err_razr_pr EXCEPTION;
err_stavka EXCEPTION;
BEGIN
SELECT min_razr,max_razr INTO minraz,maxraz FROM dolgnosti
WHERE dolgn = :new.dolgn;
IF :new.razr NOT BETWEEN minraz AND maxraz THEN RAISE err_razr; END IF;
IF :new.razr_proc NOT BETWEEN 50 AND 100 THEN RAISE err_razr_pr; END IF;
IF :new.stavka NOT BETWEEN 0.25 AND 100 THEN RAISE err_stavka; END IF;
IF :new.nachalo > :new.konec THEN RAISE nach_kon; END IF;
SELECT MAX(stroka) INTO str FROM shtat;
IF :new.stroka <> str+1 THEN RAISE err_str; END IF;
<> -- метка блока, в котором производится поиск строк с-- параметрами, аналогичными вводимым значениям
BEGIN
SELECT nachalo,konec INTO nach,kon FROM shtat
WHERE OTDEL = :new.otdel AND DOLGN = :new.dolgn AND RAZR = :new.razr
AND RAZR_PROC = :new.razr_proc AND KONEC =
(SELECT MAX(konec) FROM shtat
WHERE OTDEL = :new.otdel AND DOLGN = :new.dolgn
AND RAZR = :new.razr AND RAZR_PROC = :new.razr_proc);
IF :new.nachalo <= nach THEN RAISE nach_nach; END IF;
IF :new.nachalo <= kon THEN
UPDATE SHTAT SET konec = (:new.nachalo - 1)
WHERE OTDEL =:new.otdel AND DOLGN = :new.dolgn AND RAZR =:new.razr
AND RAZR_PROC = :new.RAZR_PROC AND konec = kon;
END IF;
EXCEPTION -- начало обработчика исключений блока find_strings
WHEN NO_DATA_FOUND THEN NULL; -- вызывается, если SELECT блока find_strings
-- не возвращает ни одной строки.
END find_strings;
EXCEP
TION -- начало обработчика исключений основной программыWHEN NO_DATA_FOUND THEN
RAISE_APPLICATION_ERROR(-20003,'Должности '||:new.dolgn||' не существует !');
WHEN err_razr THEN
RAISE_APPLICATION_ERROR(-20004,
'Значение разряда не попадает в "вилку" разрядов');WHEN err_razr_pr THEN
RAISE_APPLICATION_ERROR(-20005,
'Разрядный процент должен находиться в пределах 50-100');
WHEN err_stavka THEN
RAISE_APPLICATION_ERROR(-20006,
'Число ставок должно находиться в пределах 0.25-100');WHEN nach_nach THEN
RAISE_APPLICATION_ERROR(-20007,
'Дата начала должна быть больше '||to_char(nach));
WHEN TOO_MANY_ROWS THEN
RAISE_APPLICATION_ERR
OR(-20008,'Много строк; обратитесь к АБД.');WHEN nach_kon THEN
RAISE_APPLICATION_ERROR(-20009,
'Дата начала не может быть больше даты конца');
WHEN err_str THEN
RAISE_APPLICATION_ERROR(-20010,'Неправильный номер вводимой строки');
WHEN OTHERS THEN
RAISE_APPLICATION_ERROR(-20011,'Какая-то другая ошибка');
END shtins;
Так как в большом приложении могут часто повторяться встроенные или
пользовательские исключительные ситуации, то целесообразно создать в базе
данных таблицу (например, USERERR) с уникальными номерами (error_number) и
текстами (error_text) исключений. Это позволит избежать определения лишних
сообщений об ошибках и сделать их согласованными во всем приложении.
При использовании такой таблицы и процедуры RAISE_APPLICATION_ERROR надо
описать в в разделе DECLARE блока две переменных (например, errnum типа NUMBER
и errtext типа VARCHAR2) и использовать в обработчике исключений конструкцию:
WHEN TOO_MANY_ROWS THEN
SELECT error_number,error_text INTO errnum,errtext FROM usererr
WHERE error_number = 20008;
RAISE_APPLICATION_ERROR(errnum,errtext);
или
WHEN TOO_MANY_ROWS THEN
SELECT error_number,error_text INTO errnum,errtext FROM usererr
WHERE errtext LIKE 'Много строк; обр%';
RAISE_APPLICATION_ERROR(errnum,errtext);
12.5.2. Исключительные ситуации, определяемые пользователем
Кроме встроенных могут быть использованы собственные исключительные
ситуации, имена которых необходимо описать в разделе DECLARE блока PL/SQL
(например, err_stavka EXCEPTION). В разделе EXCEPTION блока должен быть
описан соответствующий обработчик исключительной ситуации, например
WHEN err_stavka THEN
SELECT error_number,error_text INTO errnum,errtext FROM usererr
WHERE errtext LIKE 'Число ставок должно находиться%';
RAISE_APPLICATION_ERROR(errnum,errtext);
В теле основной программы определяемые пользователем ошибки обычно проверяются
с помощью операторов условия (IF...THEN). Для передачи управления обработчику
пользовательской исключительной ситуации в случае обнаружения ошибки
используется оператор
RAISE имя_пользовательского_исключения
Например
IF :new.stavka NOT BETWEEN 0.25 AND 100 THEN
RAISE err_stavka;
END IF;
Если исключительная ситуация не обрабатывается явным образом в блоке и для
ее перехвата не используется обработчик OTHERS, то PL/SQL отменяет выполняемые
блоком транзакции и возвращает необработанную исключительную ситуацию обратно
в вызывающую среду.
Обработчик особых ситуаций OTHERS описывается последним в программе (блоке)
для перехвата всех исключительных ситуаций, которые не были описаны в этой
программе (блоке). Он может иметь вид
WHEN OTHERS THEN
RAISE_APPLICATION_ERROR(-20011,'Какая-то другая ошибка');
COMMIT - завершает транзакцию, фиксируя изменения в базе данных
ROLLBACK - отменяет изменения, внесенные текущей транзакцией
SAVEPOINT - идентифицирует промежуточную точку сохранения транзакции
(подробно будут описаны позднее)
Анонимные блоки, процедуры, функции, пакеты и триггера.
(подробно будут описаны позднее)
Oracle7 не поставляется с готовой и полной средой разработки. Поэтому для
успешной разработки с применением PL/SQL нужно освоить некоторые приемы
отладки.
Перед исполнением программы необходимо выполнить две операции:
1. Исполнить команду SET SERVEROUTPUT ON разрешающую вывод на экран
информации, заданной в процедуре
DBMS_OUT
PUT.PUT_LINE (текстовая_строка) .Эта процедура является единственным средством вывода значений переменных
из программ PL/SQL. Например,
DBMS_OUTPUT.PUT_LINE('Пример '||TO_CHAR(SYSDATE,'DD')) .
2. Установить формат даты с помощью команды
ALTER SESSION SET NLS_DATE_FORMAT='DD.MM.YYYY';
Если при выполнении SQL-запроса или программы PL/SQL обнаружены ошибки, то
в первую очередь надо проверить правильность написания в них имен таблиц,
столбцов и др. Для этого можно воспользоваться командой
SQL*Plus DESCRIBE,которая выводит список столбцов для таблицы или спецификацию для функции,
процедуры, пакета. Синтаксис этой команды имеет вид:
DESC[RIBE] {[user.]table [column] | [user.]object[.subobject]}
Пример
SQL> desc kadry
Name Null? Type
------------------------------- -------- ----
NOMER NOT NULL NUMBER(6)
FAMILIYA VARCHAR2(20)
IMYA VARCHAR2(15)
OTCHESTVO VARCHAR2(20)
ROZHDENIE DATE
POL CHAR(1)
IZMEN NOT NULL DATE
Аналогичным образом можно получить структуру любого представления словаря
данных (см. пп. 13 и 14), например, структуру user_objects, где хранится
информация о пользовательских объектах базы данных (INDEX, SEQUENCE, VIEW,
PACKAGE, PACKAGE BODY, FUNCTION, PROCEDURE, TABLE, TRIGGER):
desc user_objects
Name Null? Type
---------------- -------- ----
OBJECT_NAME VARCHAR2(128)
OBJECT_ID NUMBER
OBJECT_TYPE VARCHAR2(13)
CREATED DATE
LAST_DDL_TIME DATE
TIMESTAMP VARCHAR2(75)
STATUS VARCHAR2(7)
Для получения полного описания всех объектов можно выполнить команду:select * from user_objects;
а для получения описания процедур
select * from user_objects where object_type = 'PROCEDURE';
OBJECT_NAME OBJECT_ID OBJECT_TYPE CREATED LAST_DDL_T TIMESTAMP STATUS
----------- --------- ----------- ---------- ---------- ------------------- ----
PR_CURS 1928 PROCEDURE 17.11.1996 02.02.1997 1997-02-02:13:37:05 VALID
PR_PRINT 1957 PROCEDURE 24.11.1996 24.11.1996 1996-11-24:16:59:44 INVALID
PR_SHTAT 1970 PROCEDURE 02.01.1997 08.01.1997 1997-01-08:12:38:02 VALID
При возникновении ошибок в командах CREATE PACKAGE, CREATE PACKAGE BODY,CREATE PROCEDURE, CREATE FUNCTION, CREATE TRIGGER, CREATE VIEW их уточнение
можно выполнить с помощью команды SQL*Plus:
SHOW ERR[ORS] [{PACKAGE | PACKAGE BODY | PROCEDURE | FUNCTION |
TRIGGER | VIEW} name]
(подробности будут описаны позднее)
13. Представления словарей данных
После некоторых из перечисленных ниже имен в скобках расположен перечень
букв: (a,u), (d,u) или (a,d,u). Это означает, что такое имя является основой
для имен двух или трех словарей, получаемых за счет добавки префикса ALL_,
DBA_ или USER_. Например, TABLES(a,d,u) основа для имен словарей: ALL_TABLES,
DBA_TABLES и USER_TABLES. При этом префиксом USER снабжаются представления,
наиболее интересные для обычного пользователя, префиксом ALL снабжаются все
доступные пользователю представления и префиксом DBA - доступные пользователям
с системными полномочиями.
Таблицы, представления, синонимы, последовательности
CAT
Синоним для USER_CATALOGCATALOG(a,d,u) Информация о всех таблицах, представлениях, синонимах и
последовательностях базы данных
COL Список столбцов в таблицах пользователя.
COLS Синоним для USER_TAB_COLUMNS
COL_COMMENTS(a,d,u) Комментарии для столбцов таблиц и представлений
CONSTRAINTS(a,d,u) Информация об ограничениях ссылочной целостности в БД
CONS_COLUMNS(a,d,u) Информация о столбцах, участвующих в ограничениях
ссылочной целостностиSEQ Синоним для USER_SEQUENCES.
SEQUENCES(a,d,u) Информация о последовательностях БД
SNAPSHOTS(a,d,u) Информация о снимках в БД
SYN Синоним для USER_SYNONYMS.
SYNONYMS(a,d,u) Информация о синонимах БД
TAB Таблицы пользователя
TAB_COLUMNS(a,d,u) Информация о столбцах таблиц и представлений БД
TAB_COMMENTS(a,d,u) Комментарии для таблиц и представлений БД
TABLES(a,d,u) Информация о таблицах БД
TABS
Синоним для USER_TABLES.VIEWS(a,d,u) Информация о представлениях БД
Объекты
ERRORS(a,d,u) Информация об ошибках компиляции, обнаруженных в БД для
процедур, функций, спецификаций пакета и тел пакета
DEPENDENCIES(a,d,u) Информация о зависимостях объекта в БД
DEPTREE Информация о зависимостях объекта (создается UTLDTREE.SQL)
IDEPTREE Информация о зависимостях объекта (создается UTLDTREE.SQL)
OBJ Синоним для USE
R_OBJECTSOBJECTS(a,d,u) Информация об объектах базы данных
OBJECT_SIZE(d,u) Информация о размерах процедур, функций, спецификаций
пакетов и тел пакетов в БД
PUBLIC_DEPENDENCY Информация о зависимостях объекта
SOURCE(a,d
,u) Исходный код процедур, функций, спецификаций пакетов ител пакетов в БД
TRIGGERS(a,d,u) Информация о триггерах БД
ПривилегииCOLUMN_PRIVILEGES Информация о полномочиях для столбцов
COL_PRIVS(a,d,u)
Синоним для COLUMN_PRIVILEGESCOL_PRIVS_MADE(a,u) Информация о полномочиях, предоставляемых для столбцов
COL_PRIVS_RECD(a,u) Информация о полномочиях, полученных по конкретным
столбцам
DBA_PROFILES Информация обо всех профилях ограничений ресурсов в БД
DBA_ROLES Информация о ролях в БД
ROLE_PRIVS(d,u) Информация о назначенных пользователю ролях
ROLE_ROLE_PRIVS Информация о ролях, назначенных другим ролям
ROLE_SYS_PRIVS Информация о системных полномочиях, предоставляемых роли
ROLE_TAB_PRIVS Информация о полномочиях на объект, предоставляемых роли
SESSION_PRIVS Информация о полномочиях, предоставленных сеансу
SESSION_ROLES Информация о доступных для сеанса ролях
SYSTEM_PRIVILEGE_
MAP Отображение номеров системных полномочийSYS_PRIVS(d,u) Предоставленные пользователю системные полномочия
TAB_PRIVS(a,d,u) Информация о заданных на объекты полномочиях
TAB_PRIVS_MADE(a,u) Информация о предоставленных на объекты полномочиях
T
AB_PRIVS_RECD(a,u) Информация о полученных полномочиях на объектыTABLE_PRIVILEGES Информация о предоставленных на объекты полномочиях
TABLE_PRIVILEGE_MAP Отображение номеров полномочий
TS_QUOTAS(d,u) Информация о квотах пользователя в табличных областях
USERS(a,d,u) Информация о пользователях БД
USER_RESOURCE_LIMITS Информация о лимитах ресурсов для текущего пользователя
Табличные пространства, кластеры, экстенты, файлы,CLU Синоним для USER_CLUSTERS
CLUSTERS(d,
u) Информация об индексированных и хешированных кластерахбазы данных
CLU_COLUMNS(d,u) Отношение столбцов таблицы к ключам кластера
DBA_DATA_FILES Информация о файлах данных
EXTENTS(d,u) Информация об экстентах объектов в БД
FREE_SPACE(d,u) Информация о свободных экстентах в табличной области БД
SEGMENTS(d,u) Информация о сегментах БД
TABLESPACES(d,u) Информация о табличных областях БД
Индексы
INDEXES(a,d,u) Информация об индексах БД
IND_COLUMNS(a,d,u) Информация об индексах, соответствующих индексам таблицы
IND Синоним для USER_INDEXES.
INDEX_HISTOGRAM Статистическая информация об индексах, генерируемых
командой ANALYZE IND
EX VALIDATE STRUCTUREINDEX_STATS Статистическая информация об индексах, генерируемых
командой ANALYZE INDEX VALIDATE STRUCTURE
Загрузчик данных (SQL*Loader) и экспорт БД
LOADER_COL_INFO Информация о столбцах для
SQL*LoaderLOADER_CONSTRAINT_INFO Информация об ограничениях целостности для SQL*Loader
LOADER_INDCOL_INFO Информация об индексированных столбцах для SQL*Loader
LOADER_IND_INFO Информация об индексах для SQL*Loader
LOADER_PARAM_INFO Информация о параметрах для SQL*Loader
LOADER-TAB_INFO Информация о таблицах для SQL*Loader
LOADER_TRIGGER-INFO Информация о триггерах для SQL*Loader
DBA_EXP_FILES Описания файлов экспорта
DBA_EXP_OBJECTS Информация об объектах, инкрементально экспортированных
с помощью утилиты Export
DBA_VERSION Номер версии для последней сессии экспорта
установленной другим сеансом
Блокировки
DBA_DDL_LOCKS Информация о блокировках в результате операций DDL
DBA_DML_LOCKS Информация о блокировках DML на сервере
DBA_LOCKS Информация обо всех блокировках DDL и DML сервера БД
DBA_WAITERS Информация о сеансах, ожидающих отмены блокировки,
DBMS_LOCK_ALLOCATED Информация об определенных пользователем блокировках,
созданных пакетом утилит DBMS_LOCK
Транзакции
DBA_2PC_NEIGHBORS Информация о входящих/исходящих подключениях для
незавершенных распределенных транзакций
DBA_2PC_PENDING Информация о распределенных транзакциях, ожидающих
завершения
DBA_BLOCKERS Сеансы, которые блокируют другие транзакции (см.
соответствующее представление DBA_WAITERS)
DBA_ROLLBA
CK_SEGS Информация о сегменте отката в БДDICT Синоним для DICTIONARY
DICTIONARY Информация о таблицах и представлениях словаря данных
DICT_COLUMNS Информация о столбцах словаря данных
ERROR_COLUMNS Description of columns in data dictionary tables and views.
Другие представленияDB_LINKS(a,d,u) Информация о связях в базе данных
DBMS_ALERT_INFO Информация о зарегистрированных уведомлениях, созданных
пакетом утилит DBMS_ALERT
GLOBAL_NAME Информация о глобальных именах БД
RESOURCE_COST Информация о ценовых коэффициентах для системных ресурсов
SNAPSHOT_LOGS(d,u) Информация о журналах снимков в БД
Ревизия успешных и безуспешных обращений к объектам базы данных
ALL_DEF_AUDIT_OPTS Информация о заданных по умолчанию параметрах отслеживания
объекта
AUDIT_ACTIONS Отображение номеров действия контрольного журнала и их
описания
AUDIT_OBJECT(d,
u) Записи контрольного журнала для отслеживаемых объектовбазы данных
AUDIT_SESSION(d,u) Записи контрольного журнала, касающиеся контрольного
журнала базы данных
AUDIT_STATEMENT(d,u) Записи контрольного журнала для операторов отслеживания
AUDIT_TRAIL(d,u) Совокупность всех записей контрольного журнала
DBA_AUDIT_EXISTS Записи контрольного журнала, созданные по команде
AUDIT_EXISTS
DBA_PRIV_AUDIT_OPTS Информация о параметрах отслеживания для полномочий
DBA_STMT_AUDIT_OPTS Информация об установленных для операторов параметрах
отслеживания
OBJ_AUDIT_OPTS(d,u) Информация об установленных для объектов БД параметрах
отслеживания
STMT_AU
DIT_OPTION_MAP Отображение номеров действия контрольного журнала14. Виртуальные представления словаря данных (доступны пользователю SYS)
V$ACCESS Информация об используемых в настоящее время объектах
V$ARCHIVE Информация об архивированном журнале транзакций БД
V$BACKUP Информация о состоянии архивации всех оперативно доступных
табличных областей БД
V$BGPROCESS Информация о фоновых процессах сервера БД
V$CIRCUITS Информация обо всех подключениях пользователя в конфигурации
мультинитевого сервера
V$DATABASE Информация о БД из контрольного журнала БД
V$DATAFILE Информация о файлах данных
V$DBFILE Информация о файлах данных
V$DB_OBJECT_CACHE Информация об объектах в кэше объектов сервера БД, включая
таблицы, индексы и процедуры
V$DISPATCHERS Информация о текущих фоновых процессах диспетчера, работающих
в мультинитевом сервере БД
V$ENABLEDPRIVS Информация о разрешенных полномочиях
V$FILESTAT Информация о статистике ввода-вывода для файлов БД
V$INSTANCE Информация о текущем состоянии сервера БД (экземпляре)
V$LATCH Информация о внутренних блокировках на сервере БД
V$LATCHHO
LDER Информация о сеансах, установивших на сервере БД внутренниеблокировки
V$LATCHNAME Информация о внутренних блокировках на сервере БД
V$LIBRARYCACHE Статистическая информация об управлении библиотечным кэшем
V$LICEN
SE Информация о лицензионных ограничениях программногообеспечения Oracle7
V$LOADCSTAT Информация о статистике SQL*Loader, собранной при прямой
загрузке по маршруту
V$LOADTSTAT Информация о статистике SQL*Loader, собранной при прямой
загрузке по маршруту
V$LOCK Информация о блокировках DML на сервере БД
V$LOG Информация о журнале транзакций сервера БД
V$LOGHIST Информация о журнале транзакций сервера БД
V$LOG_HISTORY Информация о журнале транзакций сервера БД
V$LOGFILE Информация о файлах журнала транзакций сервера БД
V$NLS_PARAMETERS Информация о текущих значениях параметра NLS
V$OPEN_CURSOR Информация о каждом открытом курсоре сеанса БД
V$PARAMETER Информация о каждом параметре инициализации сервера БД
V$PROCESS Информация о текущих активных процессах
V$QUEUES Информация об очередях мультинитевого сервера
V$RECOVERY_LOG Информация об архивированных группах журнала транзакций,
необходимых для восстановления БД
V$RECOVER_FILE Информация о файлах, необходимых для восстановления БД
V$REQDIST Информация о состояниях, требующих восстановления файлов
данныхV$RESOURCE Информация о системных ресурсах
V$ROLLNAME Информация об оперативно доступных сегментах отката
V$ROLLSTAT Статистическая информация обо всех оперативно доступных
сегментах отката
V$ROWC
ACHE Статистическая информация об активности словаря данныхV$SESSION Информация о сеансах БД
V$SESSTAT Статистическая информация о сеансах БД
V$SESSION_WAIT ресурсах, которых ожидает сеанс
V$SESS_IO Информация о вводе-выводе каждого сеанса
V$SGA Информация об области памяти SGA (System Global Area) сервера
V$SGASTAT Статистическая информация об области памяти SGA сервера БД
V$SHARED_SERVERS Информация о разделяемых фоновых серверах мультинитевого
сервера БД
V$SQLAREA Информация о совместно используемых курсорах
V$SQLTEXT Информация об операторах, соответствующих совместно
используемым курсорам
V$STATNAME Информация для кодов статистики сеанса, выводимых в V$SESSTAT
V$SYSSTAT Информация о системной статистике для данных V$SESSTAT
V$THREAD Информация о нитях журнала транзакций БД
V$TIMER Текущее системное время в сотых долях секунды
V$TRANSACTION
Информация о текущих транзакциях БДV$TYPE_SIZE Информация о компонентах нижнего уровня, позволяющих
предсказать потребность в памяти на диске
V$VERSION Информация о версиях библиотек ядра программного обеспечения
сервера Oracle7V$WAISTAT Статистическая информация о конкуренции за блоки данных
между транзакциями
15. Системные полномочия Oracle7
Для системных полномочий с префиксами в скобках указаны доступные префиксы.
Например, следующая запись таблицы:
CLUSTER(CREATE,CREATE ANY, Создает, изменяет и удаляет кластеры
ALTER ANY,DROP ANY)
дает такие системные полномочия
CREATE CLUSTER Создает кластеры в своей схеме
CREATE ANY CLUSTER Создает кластеры в любой схеме
ALTER ANY CLUSTER Изменяет кластеры в любой схеме
DROP ANY CLUSTER Удаляет кластеры из любой схемы
Системные полномочия Описания
--------------------------- ------------------------------------------------
ANALYZE ANY Анализирует таблицу, индекс или кластер базы
данных с помощью команды ANALYZE
AUDIT ANY Задает для любого объекта базы данных параметры
отслеживания
AU
DIT SYSTEM Отслеживает системные событияCLUSTER(CREATE,CREATE ANY, Создает, изменяет и удаляет кластеры
ALTER ANY,DROP ANY)
DATABASE(ALTER) Модифицирует базу данных с помощью команды
ALTER DATABASE
DATABASE LINK(CREATE, Создает и изменяет связи базы данных
CREATE PUBLIC,DROP PUBLIC)
INDEX(CREATE,CREATE ANY, Создает, изменяет и удаляет индексы
ALTER ANY,DROP ANY)
PRIVILEGE(GRANT ANY) Последовательность каких-либо системных полномочий
PROCEDURE(CREATE,CREATE Создает, перекомпилирует, удаляет и выполняет
ANY,ALTER ANY,DROP ANY, процедуры, функции, пакеты и их глобальные
EXECUTE ANY) переменные
PROFILE(CREATE,ALTER,DROP) Создает, изменяет и удаляет профили ограничений
RESOURCE COST(ALTER) Создает для сеанса ценовой коэффициент ресурса
ROLE(CREATE,ALTER ANY, Создает, изменяет, удаляет и назначает роли
DROP ANY,GRANT ANY)
ROLLBACK SEGMENT(CREATE, Создает, изменяет и удаляет сегменты отката
ALTER,DROP)
SESSION(CREATE,ALTER, Создает и изменяет сеансы базы данных (RESTRICTED
RESTRICTED) соответствует созданию ограниченного сеанса)
SEQUENCE(CREATE,CREATE ANY, Создает, изменяет и удаляет последовательности
ALTER ANY,DROP ANY,
SELECT ANY)
SNAPSHOT(CREATE,CREATE ANY, Создает, изменяет и удаляет "снимки" базы данных
ALTER ANY,DROP ANY)
SYNONYM(CREATE,CREATE ANY, Создает и удаляет синонимы
DROP ANY,CREATE PUBLIC,
DROP PUBLIC)
SYSTEM (ALTER) Изменяет параметры базы данных с помощью ALTER SYSTEM
TABLE(CREATE,CREATE ANY, Создает, изменяет, удаляет, архивирует, блокирует,
ALTER ANY,BACKUP ANY,DROP комментирует таблицы и манипулирует ими
ANY,COMMENT ANY,LOCK ANY,
SELECT ANY,DELETE ANY,
INSERT ANY,UPDATE ANY)
TABLESPACE
(CREATE,ALTER, Создает, расширяет, архивирует, управляет доступностьюDROP,MANAGE,UNLIMITED) табличных областей и удаляет их, а также использует
пространство табличных областей
TRUNCATE ANY Удаляет все строки из таблицы и (необязательно)
всю выделенную для таблиц память на диске
TRANSACTION(FORCE, Управляет исходом незавершенных системных
FORCE ANY) транзакций
TRIGGER(CREATE,CREATE ANY, Создает, изменяет и удаляет триггера
ALTER ANY,DROP ANY)
USER(CREATE,ALTER,DROP, Создает, изменяет и удаляет пользователей; BECOME
BECOME) требуется для выполнения с помощью утилиты Export
полного экспорта базы данных
V
IEW(CREATE,CREATE ANY, Создает и удаляет представленияDROP ANY)
В таблице приведены полномочия на объекты (отмечены символом "*"). С
помощью ALL (All of the object privileges that can be applied.)
ПроцедурыПредста- Последова- Функции
Объекты Таблицы ления тельности Пакеты "Снимки"
ALTER * *
DELETE * *
EXECUTE *
INDEX *
INSERT * *
REFERENCES * *
SELECT * * * *
UPDATE * *
17. Основные понятия и параметры, используемые в справочнике
c_alias - псевдоним столбца (может использоваться в SELECT фразе).
cluster -
col_element - определение столбца (для формата или элемента столбца в описании
CREATE TABLE предложения).
condition - условие (возвращает логическое значение TRUE, FALSE или UNKNOWN).
constraint - имя ограничения целостности в описании таблицы.
dblink - Database link.
defoult
expr - любое выражение.
fmt - формат данных.
location - Operating-system-dependent specification of a file's location.
Usually either a device or a directory.
integer
- числовая константа или выражение типа NUMBER.nls - выражение вида 'NLS_SORT = name', где name is either
BINARY or the name of a linguistic sort sequence
null - неопределенное значение.
subquery - подзапрос, используемый в предложениях.
rowid - внутренний уникальный идентификатор строки (тип данных ROWID).
t_alias - псевдоним таблицы. Может использоваться в SELECT предложении.
schema -
scn - номер уникальной идентификации транзакции (System Change
Number).sid,serial# - Уникальные идентификаторы сессии (Session ID and serial number).