ЭЛЕКТРОННАЯ БИБЛИОТЕКА КОАПП
Сборники Художественной, Технической, Справочной, Английской, Нормативной, Исторической, и др. литературы.






       HOST

          Цель Выпoлняет команду операционной системы без выхода из SQL*PLUS

     Синтаксис HO[ST] [команда]

Термины и Фразы     команда        Задает команду операционной системы.

       Введите HOST без команды, чтобы вывести подсказку операционной 
       системы. Затем вы можете выполнить множество команд операционной 
       системы. За информацией по возврату обратно в SQL*PLUS обратитесь к 
       руководству по установке ORACLE и руководству пользователя по вашей ОС.

Рекомендации   В некоторых операционных системах можно использовать "$" или 
               другой символ вместо HOST. Смотри руководство по установке 
               ORACLE и руководство пользователя для вашей операционной 
               системы.

               В некоторых операционных системах к команде HOST нет доступа.

     Примеры   Чтобы выполнить команду операционной системы ls *.sql, 
               введите:

               SQL> HOST ls *.sql



































                                   -- 102 --



        INPUT          Цель Добавляет одну или более строк текста после 
                       текущей буфферной строки.

     Синтаксис I[NPUT] [текст]

Термины и Фразы     текст  
        Задает добавляемый текст.  Чтобы добавить одну строку, введите текст 
        строки после команды INPUT, отделив текст от команды пробелом. Чтобы 
        начать строку одним или более пробелом, введите один или более 
        пробелов между INPUT и первым непустым символом текста.

        Чтобы добавить несколько строк, введите INPUT без текста. INPUT 
        попросит вас ввести каждую строку.  Выход из INPUT- это пустая 
        введенная строка.

Рекомендации   Если вы ввели номер строки больший чем количество строк в 
               буффере и далее текст, SQL*PLUS добавит новую строку в конец 
               буффера. Если вы задали в качестве номера строки ноль (0) и 
               далее указали текст, то SQL*PLUS вставит новую строку в начало 
               буффера (данная строка получит номер 1).

     Примеры   Предположим буффер SQL содержит следующую команду:

               1 SELECT ENAME, DEPTNO, SAL, COMM
               2 FROM EMP

               Чтобы добавить фразу ORDER BY к запросу, введите:

               SQL> LIST 2
                 2* FROM EMP
               SQL> INPUT ORDER BY ENAME

          LIST 2 делает вторую строку текущей. INPUT добавляет новую строку 
          после текущей строки. Буфер SQL сейчас содержит следующие строки:

               1  SELECT ENAME, DEPTNO, SAL, COMM
               2  FROM EMP
               3* ORDER BY ENAME

               Чтобы добавить две строки с фразой WHERE, введите:

               SQL> LIST 2
                 2* FROM EMP
               SQL> INPUT
                 3  WHERE JOB = 'SALESMAN'
                 4  AND COMM=500
                 5

               INPUT попросит вас ввести новые строки, пока вы не введете 
               пустой строки. Буффер SQL сейчас содержит следующие строки:

               1  SELECT ENAME, DEPTNO, SAL, COMM
               2  FROM EMP
               3  WHERE JOB = 'SALESMAN'
               4  AND COMM=500
               5  ORDER BY ENAME



                                   -- 103 --



        LIST          Цель Выводит одну или несколько строк буффера.

     Синтаксис L[IST] [n | n m | n * | n LAST | * | * n | * LAST | LAST]

Термины и Фразы
               n         Выводит n строк.
               n m       Выводит строки с n по m.
               n *       Выводит со строки n до текущей.
               n LAST    Выводит со строки n до последней.
               *         Выводит текущую строку.
               * n       Выводит c текущей строки до строки с номером n.
               * LAST    Выводит c текущей строки до последней строки.
               LAST      Вывлдит последнюю строку.

               Введите LIST без параметров, чтобы вывести все строки.

Рекомендации   Можно опускать пробел между LIST и n или *, но но не между 
               LIST и LAST.

               Последняя выведенная строка становится новой текущей строкой 
               (помечается звездочкой).

     Примеры   Чтобы вывести содержимое буффера, введите:

               SQL> L

               Вы, наверное, увидите следующие результаты:

               1  SELECT ENAME, DEPTNO, JOB
               2  FROM EMP
               3  WHERE JOB = 'CLERK'
               4* ORDER BY DEPTNO

               Звездочка показывает, что текущей строкой стала строка с 
               номером 4.
               Чтобы вывести только вторую строку, введите:

               SQL> L 2

               Выведется следующее:

               2* FROM EMP

               Чтобы вывести с текущей строки (сейчас это строка 2) до 
               последней, введите:

               SQL> L * LAST

               Затем вы увидите следующее:

               2  FROM EMP
               3  WHERE JOB = 'CLERK'
               4* ORDER BY DEPTNO






                                   -- 104 --



        PAUSE
               Цель Выводит пустую строку, затем строку содержащую "текст", и 
               затем ожидает нажатие клавиши [Return]. Или, выводит две 
               пустые строки и устанавливается в режиме ожидания ввода.

     Синтаксис PAU[SE] [текст]

Термины и Фразы     текст          Представляет текст, который вы хотите 
                                   вывести.

               Если вы хотите вывести две пустых строки, введите PAUSE без 
               параметров.

Рекомендации   Так как PAUSE всегда ожидает отклика пользователя, лучше 
               использовать сообщение, которое явно просит нажать [Return].

               PAUSE читает ввод с терминала (если он доступен) даже, когда 
               вы переназначили источник команд ввода на файл.

               За информацией по созданию пауз между страницами отчета 
               обратитесь к описанию переменной PAUSE команды SET.

     Примеры   Чтобы вывести сообщение "Установите бумагу, нажмите Return" с 
               ожиданием нажатия клавиши [Return], вы можете включить 
               следующую команду PAUSE в командный файл:

               SQL> GET MYFILE
               1  SET PAUSE OFF
               2  PAUSE Установите бумагу и нажмите Return
               3  SELECT ...





























                                   -- 105 --



        PROMPT
                  Цель Выводит указанное сообщение или пустую строку на экран.

     Синтаксис PROMPT [текст]

Термины и Фразы     текст     Текст сообщения, которое вы хотите вывести. 
                              Если "текст" опущен, PROMPT выведет пустую 
                              строку на экран.

Рекомендации   Можно использовать данную команду в командном файле для 
               предоставления информации пользователю.

     Примеры   Следующий пример демонстрирует использование PROMPT совместно 
               с ACCEPT в командном файле ASKFORDEPT.  ASKFORDEPT содержит 
               следующие команды SQL*PLUS и SQL:

               PROMPT
               PROMPT Please enter a valid department
               PROMPT For example: 10, 20, 30, 40
               ACCEPT NEWDEPT NUMBER PROMPT 'DEPT:> '
               SELECT DNAME FROM DEPT
               WHERE DEPTNO = &NEWDEPT

               Предположим, что вы запустили данный командный файл, используя 
               START или @:

               SQL> @ASKFORDEPT

               SQL*PLUS выведет следующие подсказки:

               Please enter a valid department
               For example: 10, 20, 30, 40
               DEPT:>

Пользователь вводит номер отдела после подсказки DEPT:>.
SQL*PLUS выведет строку с &NEWDEPT до и после подстановки, и затем покажет 
наименование отдела, соответствующее введенному номеру после подсказки DEPT:>.






















                                   -- 106 --



        REMARK          Цель Начинает комментарий в командном файле.

     Синтаксис REM[ARK]

Рекомендации   Команда REMARK пишется в начале строки и комментарий заканчива-
               ется в конце строки (в строке не может быть одновременно и 
               комментарий и команда).  SQL*PLUS не интерпретирует 
               комментарий как команду.

               За информацией по вводу комментариев в командные файлы, 
               используя ограничители комментариев SQL, /*...*/, обратитесь к 
               подразделу "Помещение комментариев в командные файлы" раздела 
               "Сохранение команд для более позднего использования" в главе  3.

     Примеры   Следующий командный файл содержит несколько типичных 
               комментариев:

               SQL> GET EMPSUM
               1  REM COMPUTE uses BREAK ON REPORT to break on
               end of table
               2  BREAK ON REPORT
               3  COMPUTE SUM OF "DEPARTMENT 10" DEPARTMENT 20" -
               4  DEPARTMENT 30" "TOTAL BY JOB" ON REPORT
               5  REM Each column displays the sum of salaries by
               job for
               6  REM one of the departments 10, 20, 30.
               7  SELECT JOB,
               8        SUM( DECODE( DEPTNO, 10, SAL, 0))
               "DEPARTMENT 10",
               9        SUM( DECODE( DEPTNO, 20, SAL, 0))
               "DEPARTMENT 20",
               10       SUM( DECODE( DEPTNO, 30, SAL, 0))
               "DEPARTMENT 30",
               11       SUM(SAL) "TOTAL BY JOB"
               12 FROM EMP
               13*GROUP BY JOB























                                   -- 107 --



        RUN          Цель Выводит и выполняет команду SQL или блок PL/SQL 
                     запомненный в буффере SQL.

     Синтаксис R[UN]

Рекомендации   RUN приводит к тому, что последняя строка буффера SQL 
               становится текущей.

               Команда "наклонная черта" (/) аналогична RUN, но она не 
               выводит содержимое буффера на терминал.

     Примеры   Предположим, буффер SQL содержит следующий запрос:

               SELECT DEPTNO FROM DEPT

               Чтобы выполнить запрос, введите:

               SQL> RUN

               Вы получите следующий результат:

               1*  SELECT DEPTNO FROM DEPT

                   DEPTNO
               ----------
                      10
                      20
                      30
                      40






























                                   -- 108 --



        RUNFORM          Цель Вызывает приложение SQL*Forms из SQL*PLUS.

     Синтаксис RUNFORM [опции] имя_формы

Рекомендации   Синтаксис команды RUNFORM такой же, как и у SQL*PLUS.  Если вы 
               уже находитесь в SQL*PLUS, данным способом можно вызвать форму 
               более быстрее, чем активизация формы после системной подсказки,
               так как вы избегаете повторного логирования к ORACLE. Подробно-
               сти о синтаксисе смотри в "Руководство опреатора по SQL*Forms".

               Заметим, что если вы используете RUNFORM  из SQL*PLUSа, вы 
               можете не указывать имя/пароль пользователя (SQL*PLUS возьмет 
               текущие значения).  Если вы хотите использовать другие 
               имя/пароль пользователя, используйте SQL*PLUS-команду CONNECT 
               для подключения к необходимому пользователю.

     Примеры   Для выполнения формы с именем MYFORM, введите:

               SQL> RUNFORM MYFORM








































                                   -- 109 --




        SAVE          Цель Сохраняет содержимое буффера в файле операционной 
                      системы (комндный файл).

     Синтаксис SAV[E] имя_файла[.ext] [CRE[ATE] | REP[LACE] | APP[END]]

Термины и Фразы     имя_файла[.ext]
     Задает имя файла, в котором вы хотите сохранить содержимое буффера. Если 
     вы не указали расширение, SQL*PLUS использует расширение по умолчанию 
     (обычно SQL).  Информация о изменении расширения по умолчанию приводится 
     при описании переменной SUFFIX команды SET в данной главе.

      Если вы указываете одну из фраз CREATE, REPLACE, APPEND, то необходимо 
     явно указать расширение файла.

     CRE[ATE]     Создает файл, если он не существует.

     REP[LACE]    Замещает содержимое существующего файла.  Если файл не 
                  существует, REPLACE создает его.

     APP[END]     Добавляет содержимое буффера в конец указанного вами файла.

Рекомендации   Когда вы сохраняете содержимое буффера SQL, SAVE добавляет 
               строку с наклонной чертой (/) в конец файла.

     Примеры   Чтобы сохранить содержимое буффера в файл DEPTSALPRT с 
               расширением SQL, введите:

               SQL> SAVE DEPTSALPRT

               Чтобы сохранить содержимое буффера в файл DEPTSALPRT с 
               расширением OLD, введите:

               SQL> SAVE DEPTSALPRT.OLD

























                                   -- 110 --



        SET          Цель Настраивает окружение SQL*PLUS для текущего сеанса:

                    * устанавливает ширину вывода данных NUMBER
                    * устанавливает ширину вывода данных LONG
                    * разрешает/запрещает печать заголовков колонок
                    * устанавливает количество строк на странице
                    * .......

     Синтаксис SET системная_переменная значение
               где системная_переменная является одним из следующих значений:

               ARRAY[SIZE] {20 | n}
               AUTO[COMMIT] {OFF | ON | IMM[EDIATE]}
               BLO[CKTERMINATOR] {. | c}
               CMDS[EP] {; | c | OFF | ON}
               COM[PATIBILITY] {V5 | V6}
               CON[CAT] {. | c | OFF | ON}
               COPYC[OMMIT] {0 | n}
               CRT crt
               DEF[INE] {& | c | OFF | ON}
               ECHO {OFF | ON}
               EMBEDDED {OFF | ON}
               ESC[APE] {\ | c | OFF | ON}
               FEED[BACK] {6 | n | OFF | ON}
               FLU[SH] {OFF | ON}
               HEA[DING] {OFF | ON}
               HEADS[EP] {| | c | OFF | ON}
               LIN[ESIZE] {80 | n}
               LONG {80 | n}
               MAXD[ATA] n
               NEWP[AGE] {1 | n}
               NULL текст
               NUMF[ORMAT] формат
               NUM[WIDTH] {10 | n}
               PAGES[IZE] {14 | n}
               PAU[SE] {OFF | ON | текст}
               RECSEP {WR[APPED] | EA[CH] | OFF}
               RECSEPCHAR {_ | c}
               SCAN {OFF | ON}
               SHOW[MODE] {OFF | ON}
               SPA[CE] {1 | n}
               SQLC[ASE] {MIX[ED] | LO[WER] | UP[PER]}
               SQLCO[NTINUE] {>  | текст}
               SQLN[UMBER] {OFF | ON}
               SQLPRE[FIX] {# | c}
               SQLP[ROMPT] {SQL> | текст}
               SQLT[ERMINATOR] {; | c | OFF | ON}
               SUF[FIX] {SQL | текст}
               TAB {OFF | ON}
               TERM[OUT] {OFF | ON}
               TI[ME] {OFF | ON}
               TIMI[NG] {OFF | ON}
               TRIM[OUT] {OFF | ON}
               UND[ERLINE] {- | c | OFF | ON}
               VER[IFY] {OFF | ON}
               WRA[P] {OFF | ON}



                                   -- 111 --



Термины и Фразы
     ARRAY[SIZE] {20 | n}
               Устанавливает количество строк <называется пакетом>, которые 
               SQL*PLUS выбирает из БД за один раз. Допустимое значение от 1 
               до 5000. Большее число повышает эффективность запросов и 
               подзапросов, выбирающих много записей, но требует больше 
               памяти в операционной системе. ARRAYSIZE не влияет на 
               выполнение операций SQL*PLUS.

     AUTO[COMMIT] {OFF | ON | IMM[EDIATE]}
               Задает время проведения отложенных изменений в базе данных. ON 
               заставляет SQL вносить произведенные изменения в БД сразу же 
               после выполнения любой команды SQL или блока PL/SQL. OFF 
               отменяет автоматическое сохранение, и вам придется 
               самостоятельно сохранять изменения (например, командой SQL 
               COMMIT). IMMEDIATE- эквивалентна опции ON.

     BLO[CKTERMINATOR] {. | c}
               Устанавливает неалфавитно-цифровой символ, используемый в 
               конце блоков PL/SQL. Чтобы выполнить блок, вы должны 
               использовать команды RUN или /.


     CMDS[EP] {; | c | OFF | ON}
               Устанавливает неалфавитно-цифровой символ, используемый для 
               разделения нескольких команд SQL*PLUS, вводимых на одной 
               строке. ON/OFF разрешает/запрещает использование нескольких 
               команд на одной строке; ON автоматически устанавливает точку с 
               запятой (;) в качестве символа разделителя команд.


     COM[PATIBILITY] {V5 | V6}
               Задает, сохранять или нет SQL*PLUSу команды COMMIT и ROLLBACK 
               в буффере SQL.  V5 не сохраняет COMMIT и ROLLBACK в буффере 
               SQL; V6- наоборот; Установите COMPATIBILITY в V5, если вы 
               хотите выполнить командный файл, разработанный для пятой 
               версии ORACLE; ... V6- для шестой версии ORACLE.

               Смотрите описание команд COMMIT и ROLLBACK в "Справочное 
               руководство по языку SQL".

     CON[CAT] {. | c | OFF | ON}
               Устанавливает символ, который вы можете использовать для 
               разделения имени подстановочной переменной от другого текста, 
               если он примыкает вплотню к данной переменной. Если вы задали 
               COMCAT ON, то SQL*PLUS восстанавливает значение символа по 
               умолчанию, т.е. точку.

     COPYC[OMMIT] {0 | n}
               Задает количество пакетов, после которых команда COPY 
               производит изменения в БД.  Команда COPY производит изменения 
               строк в целевой БД каждый раз, когда он скопирует n  пакетов 
               строк. Допустимое значение от 0 до 5000. Длина пакета задается 
               переменной ARRAYSIZE. Если вы задали COPYCOMMIT в 0, то COPY 
               производит изменения только после окончания операции 
               копирования.



                                   -- 112 --



     CRT crt   Изменяет CRT-файл по умолчанию, используемый командой SQL*PLUS 
               RUNFORM. Чтобы восстановить первоначальное имя crt, задайте 
               SET CRT "".

               Вы можете задавать имя-crt при вызове формы:

               SQL> RUNFORM -c NEW имя_формы
           или
               SQL> SET CRT NEW
               SQL> RUNFORM имя_формы

               При втором способе, SQL*PLUS запоминает имя-crt поэтому, при 
               вызове формы не надо задавать имя-crt в течение данного 
               сеанса.

     DEF[INE] {& | c | OFF | ON}
               Устанавливает символ "c", используемый как префикс пoдстановоч-
               ной переменной.  ON/OFF включает/выключает поиск и замену 
               подстановочной переменной ее значением.  Установка DEFINE в ON 
               или OFF переопределяет значение установки переменной SCAN.

     ECHO {OFF | ON}
               Задает или запрещает вывод выполняемых команд из командного 
               файла, запущенного командой START. ON разрешает вывод команд; 
               OFF-запрещает.

     EMBEDDED {OFF | ON}
               OFF означает, что каждый отчет будет начинаться от начала новой
               страницы. При ON- будет начинаться с любого места страницы.

     ESC[APE] {\ | c | OFF | ON}
               "c" определяет ESCAPE-символ. 
               OFF отменяет этот символ. 
               ON  разрешает ESCAPE-символ.

               Если ESCAPE-символ определен, то его можно использовать, 
               например, перед символом, объявленным в команде DEFINE, для 
               обозначения того, что такой символ является обычным символом.

     FEED[BACK] {6 | n | OFF | ON}
               Выводит количество записей выбранных при запросе в момент 
               выбора n записей.  ON/OFF включает/выключает эту команду.  При 
               установке ON n устанавливается в 1. Установка n в 0 
               равнозначна установке OFF.


     FLU[SH] {OFF | ON}
               Задает, когда посылать результаты на устройство вывода 
               пользователя. OFF разрешает операционной системе буфферный 
               вывод. ON запрещает буфферизацию.

               OFF следует применять для командных файлов работающих не 
               интерактивно (т.е., когда нет необходимости в выводимых 
               сообщениях пока не закончится командный файл). Чем меньше 
               операций ввода/вывода, тем быстрее работает программа.




                                   -- 113 --



     HEA[DING] {OFF | ON}
               Управляет печатью заголовков колонок. 
          ON    заставляет SQL  печатать заголовки в отчетах; 
          OFF - запрещает; 
          HEADS[EP] {| | c | OFF | ON} 
          Устанавливает символ разделитель заголовка.  Можно использовать 
          данный символ в команде COLUMN или в старых формах BTITLE и TTITLE 
          для разделения заголовков на несколько строк.  ON/OFF влючают/выклю-
          чают разделитель. Когда разделитель заголовков выключен, SQL*PLUS 
          воспринимает символ-разделитель как обычный символ.

     LIN[ESIZE] {80 | n}
          Устанавливает длину строки. Также контролирует позицию 
          центрирования и выравнивания текста вправо в BTITLE и TTITLE.  
          Допустимое значение от 1 до 500.

     LONG {80|n}
           Устанавливает максимальную длину LONG-значений для вывода и 
          копирования.  Допустимые значения от 1 до 32767. Значение 
          переменной LONG должно быть меньше, чем MAXDATA.

     MAXD[ATA] n
          Устанавливает максимальную ширину строки, которую SQL*PLUS может 
          обрабатывать.  Максимальное и значение по умолчанию для n зависит 
          от типа операционной системы. Смотри руководство по установке 
          ORACLE и руководство пользователя для вашей ОС, или обратитесь к 
          администратору БД.

     NEWP[AGE] {1 | n}
          Устанавливает количество пустых строк, печатаемых между началом 
          каждой страницы и верхним заголовком. Значение, равное нулю, 
          заставляет SQL*PLUS выводить между страницами символ перевода листа 
          и очищать экран на большинстве типов терминалов.

     NULL текст
          Устанавливает текс, который SQL*PLUS отображает для представления 
          пустой величины.  NULL без указания "текста" побуждает SQL*PLUS 
          выводить пробелы (по умолчанию). Используйте фразу NULL команды 
          COLUMN для замены данного значения для некоторой колонки.

     NUMF[ORMAT] формат
          Устанавливает формат, используемый по умолчанию для вывода на экран 
          числовых элементов данных. Укажите числовой формат для "формат". 
          Описание форматов смотри в описании фразы FORMAT команды COLUMN.  

     NUM[WIDTH] {10 | n} Устанавливает ширину, используемую по умолчанию для 
          вывода чисел.

     PAGES[IZE] {14 | n}
          Устанавливает количество строк между заголовком и концом страницы. 
          Для листа в 11 дюймов задают 54 (плюс NEWPAGE=6).  Вы можете yстано-
          вить PAGESIZE в 0, чтобы подавить все заголовки, прерывания страниц,
          начальные пустые строки и другую информацию для форматирования.

     PAU[SE] {OFF | ON | текст}
          Позволяет управлять скролированием на терминале во время выполнения 
          отчета. Вы должны нажать [Return] или [Clear] после каждой паузы. 
          ON заставляет SQL*PLUS создавать паузу перед выводом каждой 

                                   -- 114 --



          страницы отчета. Текст определяет сообщение SQL*PLUSа во время 
          паузы. Текст с пробелами необходимо заключать в одиночные кавычки.  
          Можно использовать терминальные escape последовательности в команде 
          PAUSE; т.е.  можно вывести сообщение в инверсном режиме и т.д.

     RECSEP {WR[APPED] | EA[CH] | OFF} и RECSEPCHAR  {|c}
          Выводит или печатает разделитель записей.  Разделитель записей 
          состоит из одной строки, в которой символ "c" повторяется LINESIZE 
          раз.  RECSEPCHAR описывает символ разделения записей. По умолчанию- 
          это пробел.

          RECSEP сообщает SQL*PLUS, где необходимо отбражать разделение 
          записей. Например, если RECSEP WRAPPED, то SQL*PLUS выведет 
          разделитель записей только после свернутой строки; если RECSEP 
          EACH, то разделитель будет выводиться после каждой записи. Если вы 
          установите RECSEP в OFF, то SQL*PLUS не будет выводить символ 
          разделитель записей.

     SCAN {OFF | ON}
          OFF запрещает обработку подстановки переменных и параметров; ON- 
          разрешает.

     SHOW[MODE] {OFF | ON}
          Управляет выводом старого и нового значения системных переменных 
          SQL*PLUS, когда вы их изменяете командой SET.

     SPA[CE] {1 | n}
          Устанавливает количество пробелов между колонками при выводе. 
          Максимальное значение n равно 10.

     SQLC[ASE] {MIX[ED] | LO[WER] | UP[PER]}
          Переводит регистр команд SQL или блоков PL/SQL перед выполнением. 
          SQL*PLUS переводит весь текст команды, включая литералы в кавычках, 
          следующим образом:

          * верхний регистр, если SQLCASE=UPPER
          * нижний регистр, если SQLCASE=LOWER
          * без изменения, если SQLCASE=MIXED

          SQLCASE не изменяет содержимое буффера SQL.

     SQLCO[NTINUE] {>  | текст}
          Устанавливает последовательность символов, выводящихся в качестве 
          подсказки для продолжения командной строки SQL*PLUS (для 
          продолжения используют символ переноса "-").

     SQLN[UMBER] {OFF | ON}
          ON устанавливает, что для второй и последующих строк команды SQL 
          подсказкой будет номер строки. OFF позволяет изменять подсказку 
          через SQLPROMPT.

     SQLPRE[FIX] {# | c}
          Устанавливает символ префикса SQL. В то время, как вы выводите 
          команду SQL*PLUS за подсказкой SQL>, вы можете на отдельной строке, 
          которой предшествует символ префикса SQL, ввести команду SQL. SQL 
          будет выполнять команду SQL, независимо от того, что введена 
          команда SQL*PLUS.


                                   -- 115 --



SQLP[ROMPT] {SQL> | текст}
          Устанавливает командную подсказку SQL*PLUS.

SQLT[ERMINATOR] {; | c | OFF | ON}
          Устанавливает символ, использующийся для завершения команды SQL. 
          OFF означает, что отменяются все символы окончания команды SQL; 
          пользователь заканчивает команду SQL, вводом пустой строки. ON 
          устанавливает символ окончания в значение по умолчанию (;).

SUF[FIX] {SQL | текст}
          Устанавливает использующееся по умолчанию расширение имени файла, 
          которое SQL*PLUS использует в командах, ссылающиеся на командные 
          файлы. SUFFIX не влияет на расширение файла для вывода (при 
          буфферизации).

TAB {OFF | ON}
          OFF заставляет SQL*PLUS использовать символ табуляции для 
          форматирования абзаца в выходных данных. ON заставляет SQL*PLUS 
          использовать для этого пробелы. Значение для TAB по умолчанию 
          является системно-зависимым.  Введите SHOW TAB для того, чтобы 
          посмотреть значение по умолчанию для вашей системы.

TERM[OUT] {OFF | ON}
          OFF запрещает отображение выходных данных, генерируемых командами, 
          выполняющимися из файла, в результате чего вывод может быть 
          буфферизован без вывода экран. ON разрешает отбражение выходных 
          данных. TERMOUT OFF не влияет на вывод команд введенных 
          интарактивно.

TI[ME] {OFF | ON}
          ON заставляет SQL*PLUS отображать текущее время перед каждой 
          командной подсказкой. OFF запрещает вывод времени.

TIMI[NG] {OFF | ON}
          Управляет выводом временной статистики. ON выводит временную 
          статистику по каждой выполненой команде SQL или блоку PL/SQL. OFF 
          запрещает вывод. Информацию о SET TIMING ON смотри в руководстве по 
          установке пользователя и в руководстве пользователя по вашей 
          опреационной системе.

TRIM[OUT] {OFF | ON}
          Определяет, как выводит SQL*PLUS конечные пробелы в конце каждой 
          строки. ON удаляет пробелы в конце каждой строки, улучшая 
          характеристики при взаимодествии с ORACLE через медленные 
          устройства. OFF разрешает отображение завершаюших пробелов. TRIMOUT 
          ON не привязан к буфферному выводу; он игнорируется, если не 
          установлен SET TAB ON.

UND[ERLINE] {- | c | OFF | ON}
          "c" устанавливает символ, использующийся для подчеркивания 
          заголовков столбцов в отчетах SQL*PLUS. ON/OFF включает/выключает 
          подчеркивание, независисмо от значения "c".

VER[IFY] {OFF | ON}
          ON заставляет SQL*PLUS выводить текст командной строки до и после 
          замещения указателей подставляемых переменных действительными 
          величинами. OFF отменяет вывод.


                                   -- 116 --



WRA[P] {OFF | ON}
          OFF отсекает отображаемые элементы данных, если их длина больше 
          ширины текущей строки.  ON разрешает элементам данных 
          "переноситься" на следующую строку.

          Используйте фразы WRAPPED и TRUNCATED команды COLUMN, чтобы 
          отменить установки WRAP для описанных столбцов.

Рекомендации   SQL*PLUS поддерживает системные переменные (их также называют 
               переменными команды SET), которые позволяют настраивать 
               окружение SQL*PLUS в данном сеансе. Можно изменять их значения 
               командой SET и смотреть их текущие значения командой SHOW.

               Замечание:  SET TRANSACTION READ ONLY является командой SQL; 
               смотри справочное руководство по языку SQL.

     Примеры   Рассмотрим несколько примеров использования переменных команды 
               SET.

   COMPATIBILITY  Чтобы выполнить командный файл, SALARY.SQL, созданный для 
               версии 5 ORACLE, введите:

               SQL> SET COMPATIBILITY V5
               SQL> START SALARY

               После выполнения файла, восстановим режим эмуляции в V6:

               SQL> SET COMPATIBILITY V6

               Вы можете добавить команду SET COMPATIBILITY V5 в начало 
               командного файла, и восстановить эмуляцию в конце командного 
               файла SET COMPATIBILITY V6.

         ESCAPE  Если вы задали escape-символ равным "!", то

               SQL> ACCEPT v1 PROMPT 'Enter !&1:'

               выведет следующую подсказку:

               Enter &1:

         HEADING  Для подавления вывода заголовков колонок в отчете, введите:

               SQL> SET HEADING OFF

               Если вы после этого выполните SQL команду SELECT,

               SQL> SELECT ENAME, SAL FROM EMP
                 2  WHERE JOB = 'CLERK';

               то получите следующие результаты:

               ADAMS          1100
               JAMES           950
               MILLER    1300




                                   -- 117 --



         LONG  Чтобы установить максимальную ширину выводимых и копируемых 
               LONG-значений равной 500, введите:

               SQL> SET LONG 500

               LONG-данные будут свернуты при выводе на терминал;
               SQL*PLUS будет обрезать данные длинее 500 символов.

     SQLCONTINUE  Чтобы установить подсказку продолжения команд SQL*PLUS 
               равной восклицательному знаку и пробелу, введите:

               SQL> SET SQLCONTINUE '! '

               SQL*PLUS будет выдавать новыю подсказку для строк-продолжений:

               SQL> TTITLE 'YEARLY INCOME' -
               ! RIGHT SQL.PNO SKIP 2 -
               ! CENTER 'PC DIVISION'
               SQL>

          SUFFIX  Чтобы установить расширение для командных файлов по 
                  умолчанию равным UFI, введите:

               SQL> SET SUFFIX UFI

               Если вы введете

               SQL> GET EXAMPLE

               То SQL*PLUS будет искать файл EXAMPLE.UFI вместо EXAMPLE.SQL





























                                   -- 118 --



        SHOW          Цель Выводит значения системных переменных SQL*PLUS.

     Синтаксис SHO[W] опция
               где опция есть одна из следующих фраз:
               системная_переменная
               ALL
               BTI[TLE]
               LNO
               PNO
               REL[EASE]
               SPOO[L]
               SQLCODE
               TTI[TLE]
               USER

Термины и Фразы     системная_переменная  Любая системная, установленная 
                                  командой SET.

               ALL                Выводит установки для всех опций SHOW.

               BTI[TLE]           Показывает текущее определение BTITLE.

               LNO                Показывает текущий номер строки (позиция на 
                                  текущей странице дисплея или 
                                  буфферизованного вывода).

               PNO                Показывает текущий номер страницы.
               REL[EASE]          Показывает номер реализации ORACLE RDBMS, с 
                                  которым работает SQL*PLUS.

               SPOO[L]            Показывает, является ли текущий вывод 
                                  буфферизованным.

               SQLCODE            Показывает значение SQL.SQLCODE (код 
                                  возврата последней выполненой команды)

               TTI[TLE]           Показывает текущее определение TTITLE.

               USER               Показывает имя пользователя, с которым вы 
                                  подключились к SQL*PLUS.

Рекомендации   Чтобы посмотреть текущее значение LINESIZE, введите:

               SQL> SHOW LINESIZE

               Если текущее значение переменной равно 80, SQL*PLUS выдаст 
               следующее:

               linesize 80










                                   -- 119 --



        SPOOL

  Цель Сохраняет результаты запросов в файле операционной системы и, обычно, 
посылает данный файл на принтер. Также показывает текущее состояние 
буфферизации.

     Синтаксис SPO[OL] [имя_файла[.ext] | OFF | OUT

Термины и Фразы     имя_файла[.ext] 
Задает имя файла, в который будет производиться буферизация отображаемых 
выходных данных. Если вы не указали расширение, SPOOL использует расширение 
по умолчанию (LST или LIS в большинстве систем).

               OFF            Заставляет SQL остановить буферизацию.

               OUT            Останавливает буферизацию и посылает файл на 
                              принтер.

               Введите SPOOL без параметров, чтобу вывести текущее состояние 
               буферизации.

Рекомендации   Чтобы буферировать вывод генерируемый командами из командного 
               файла без отображения его на экране, используйте SET TERMOUT 
               OFF. SET TERMOUT OFF не влияет на вывод команд, введенных 
               интерактивно.

     Примеры   Чтобы начать запись отображаемых данных в файл с именем DIARY, 
               введите:

               SQL> SPOOL DIARY

               Чтобы закрыть и распечатать файл, введите:

               SQL> SPOOL OUT

























                                   -- 120 --



        SQLPLUS
          Цель Стартует SQL*PLUS (вводится после системной подсказки).

     Синтаксис SQLPLUS [[-S[ILENT]] [logon] [start]] | -?
          где:
               logon          Требутся следующий синтаксис:

               имя_пользователя[/пароль][@спецификация_базы] |
                         / |
                         /NOLOG

               start     Позволяет вводить имя командного файла и аргументы. 
                         SQL*PLUS передает аргументы командному файлу 
                         аналогично команде START. Фраза START задается в 
                         следующем формате:

                         @имя_файла[.ext] [арг1 арг2 ...]

                         Смотри описание команды START в данной главе.

Термины и Фразы     Если вы не указали logon и задали start, SQL*PLUS 
        подразумевает, что первая строка командного файла содержит правильный 
        logon. Если вы не задали ни logon ни start, SQL*PLUS выдаст подсказку 
        для ввода имени и пароля пользователя.

    имя_пользователя[/пароль]
              Задает имя и пароль пользователя, с которым вы хотите 
                 подключиться к ORACLE.  Если вы опустили эти параметры, 
                 SQL*PLUS попросит вас ввести их. Если вы ввели наклонную 
                 черту (/) или просто нажмете [Return] на подсказке 
                 user_name, SQL*PLUS подключит вас, используя logon по 
                 умолчанию (см "/" ниже).

              Если вы опустили только пароль, SQL*PLUS попросит вас ввести 
                 его. Вводимый вами пароль после подсказки неотображается на 
                 экране.

              Представляет logon по умолчанию (ops$).  Вы не можете ввести 
                 спецификацию_базы, если вы используете logon по умолчанию.  
                 По умолчанию logon SQL*PLUS попытается подключить вас, 
                 используя имя пользователя OPS$имя, где "имя" есть ваше имя 
                 в операционной системе.

    /NOLOG    Заставляет стартовать SQL*PLUS, но не производить вашу 
                 регистрацию в ORACLE.  Перед выполнением любой команды, 
                 необходимо выполнить команду CONNECT с правильным logon, 
                 чтобы подключиться к ORACLE.

    спецификация_базы
              Состоит из SQL*NET-строки подключения.  Синтаксис данной строки 
              зависит от типа протокола связи вашего ORACLE.  Дополнительную 
              информацию смотрите в руководстве по SQL*NET или спросите у 
              администратора БД.

    -S[ILENT] Подавляет все информационные и запрашивающие сообщения 
              SQL*PLUS, включая командную подсказку 'SQL >' и названия 



                                   -- 121 --



              программ, которые обычно отображаются во время запуска 
              SQL*PLUS. Это используется для того, чтобы сделать вызов 
              SQL*PLUS другими программами невидимым для пользователя.

    -?        Заставляет SQL*PLUS отбразить номер текущей версии, а затем 
              передать управление операционной системе. Оба знака нельзя 
              разделять пробелом.

Рекомендации
  SQL*PLUS может настраиваться с помощью файла параметров (profile), 
создаваемого администратором базы.  SQL*PLUS выполняет этот командный файл, 
когда пользователь запускает SQL*PLUS и устанавливает связь с ORACLE. Данный 
файл параметров позволяет ДБА настраивать среду по умолчанию для все 
пользователей данной системы; пользователи не имеют доступа к данному файлу 
параметров. Имя данного файла зависит от типа операционной системы. Подробнее 
о файле параметров смотри в руководстве по установке ORACLE.

  SQL*PLUS также поддерживает файл параметров пользователя (User Profile), 
выполняемого после главного файла параметров.  SQL*PLUS ищет файл с именем 
LOGIN.SQL в вашем текущем директории. Если SQL*PLUS не обнаружит этого файла 
здесь, то SQL*PLUS будет искать данный файл в директориях заданных в пути. 
Некоторые операционные системы не поддерживают возможность путь-поиска. Если 
SQL*PLUS не обнаружит LOGIN-файл, он выведет предупреждаюшее сообщение и 
продолжит процесс регистрации.


     Примеры   Для запуска SQL*PLUS с именем SCOTT и паролем TIGER, введите:

               SQLPLUS SCOTT/TIGER

               Чтобы сделать то же самое и задать базу POLICY по умолчанию, 
               введите:

               SQLPLUS SCOTT/TIGER@POLICY

               Чтобы запустить командный SQL*PLUS и выполнить командный файл 
               STARTUP.SQL, введите:

               SQLPLUS SCOTT/TIGER @STARTUP




















                                   -- 122 --



        START          Цель Выполняет указанный командный файл.

     Синтаксис STA[RT] имя_файла[.ext] [арг1 арг2 ...]

Термины и Фразы     имя_файла[.ext] 
   Задает командный файл, который вы хотите выполнить. Этот файл содержит 
любые команды, которые вы можете выполнять интерактивно.

Если вы не указали расширение, SQL*PLUS использует расширение по умолчанию 
(обычно SQL). За информацией по изменению расширения по умолчанию обратитесь 
к описанию переменной SUFFIX команды SET в данной главе.

Когда вы ввели START имя_файла.ext, SQL*PLUS будет искать данный файл в 
текущем директории. Если SQL*PLUS не обнаружит данный файл, то он повторит 
поиск в директориях, заданных в пути для операционной системы. Некоторые 
операционные системы могут не поддерживать возможность путь-поиска.

[арг1 арг2 ...]   Определяет аргументы, передаваемые командному файлу. Если 
              вы ввели один или более аргументов, SQL*PLUS подставит данные 
              значения в параметры (&1,&2, ...) командного файла.  Первый 
              аргумент замещает &1, второй замещает &2, и т.д.

               Команда START присваивает параметрам значения аргументов; если 
               вы стартуете снова этот командный файл в данном сеансе, вы 
               можетет задать новые значения или опустить аргументы, для 
               использования старых значений.

               Подробнее о использовании параметров смотрите в подразделе 
               "Передача параметров с помощью команды START" раздела 
               "Написание интерактивных команд" в главе 3.

Рекомендации   Команда @ (знак "at") работает аналогично START, но она не 
               позволяет передавать параметры.

     Примеры   Файл с именем PROMOTE.SQL, используемый для содействия 
               служащим, может содержать следующую команду:

               SELECT * FROM EMP
               WHERE MGR=&1 AND JOB=&2 AND SAL>&3;

               Чтобы выполнить данный командный файл, введите:

               SQL> START PROMOTE 7280 CLERK 950

               Затем SQL*PLUS выполнит следующую команду:

               SELECT * FROM EMP
               WHERE MGR=7280 AND JOB='CLERK' AND SAL>950;











                                   -- 123 --



        TIMING          Цель Записывает данные хронометрирования о общем 
                        времени выполнения команд, выводит заголовок текущей 
                        области хронометрирования и ее данные, или выводит 
                        количество активных областей хронометрирования.

     Синтаксис TIMI[NG] [START текст | SHOW | STOP]

Термины и Фразы     START текст
   Устанавливает область хронометрирования и делает текст заголовком данной 
области.  Вы можете иметь более одной активной области хронометрирования, 
посредством старта дополнительной области, не остановив предыдущую область 
хронометрирования. Последняя запущенная область хронометрирования становится 
текущей.

SHOW      Выводит заголовок текущей области хронометрирования и ее данные.

STOP          Выводит заголовок текущей области хронометрирования и ее 
          данные, затем удаляет данную область. Если существуют еще активные 
          области хронометрирования, одна из них, созданная самой последней, 
          которая еще не уничтожена, становится текущей. Используйте фразу 
          TIMING в команде CLEAR для удаления всех активных областей.

Для отображения количества активных областей хронометрирования используйте 
TIMING без параметров.

Рекомендации   Вы можете использовать эти данные для анализа эффективности 
               некоторых команд или блоков PL/SQL.

               За подробностями обратитесь к руководству по установке ORACLE 
               и руководству пользователя для вашей операционной системы. 
               Смотрите команду SET TIMING ON, для отображения текущего 
               времени после каждой выполненной команды или блока PL/SQL.

     Примеры   Для создания области хронометрирования с именем SQL_AREA, 
               введите:  SQL> TIMING START SQL_AREA

               Для вывода заголовка текущей области
               хронометрирования и накопленных данных, введите:
               SQL> TIMING SHOW

               Для вывода заголовка текущей области хронометрирования и 
               накопленных данных, и уничтожения данной области введите:

               SQL> TIMING STOP















                                   -- 124 --



        TTITLE          Цель Помещает и форматирует указанный заголовок 
                        вверху каждой страницы отчета, или выводит текущее 
                        определение TTITLE.

Замечание:  Описание старого формата TTITLE, совместимого с UFI (предшествен
            ник SQL*PLUS), смотри TTITLE(старый формат) в приложении F.

     Синтаксис TTI[TLE]  [printspec [текст | переменная] ...] | [OFF | ON]

               где printspec состоит из одной или нескольких следующих фраз, 
               используемых для размещения и форматирования текста:

               COL n
               S[KIP] [n]
               TAB n
               LE[FT]
               CE[NTER]
               R[IGHT]
               BOLD
               FORMAT char

Термины и Фразы     Если вы не указали фразу printspec перед текстом, TTITLE 
     выравнит текст влево. Для вывода текущего определения TTITLE, введите 
     TTITLE  без параметров.

     Описание данных терминов и фраз действительно и для команды BTITLE.

     текст     Задает текст заголовка. Текст необходимо поместить в одиночные 
               кавычки, если в нем больше одного слова.

     переменная     Задает пользовательскую переменную или одну из следующих 
                    системных переменных:

               * SQL.LNO (текущий номер строки)
               * SQL.PNO (текущий номер страницы)
               * SQL.RELEASE (текущий номер реализации ORACLE)
               * SQL.SQLCODE (текущий код ошибки)
               * SQL.USER (текущее имя пользователя)

     Чтобы вывести одно из этих значений, используйте соотвествующее имя в 
     заголовке. Можно форматировать переменную фразой FORMAT.

     OFF       Выключает заголовок (запрещает его вывод) не влияя на его 
               описание.

     ON        Включает заголовок (разрешает его вывод). Когда вы описали 
         верхний заголовок, SQL*PLUS автоматически устанавливает TTITLE в ON.

     COL n     Перемещение в колонку n текущей строки.  "Колонка" в данном 
                       контексте означает позицию печати, но не колонку таблицы.

     S[KIP] [n]  Пропуск n строк; если вы опустили n, пропускается одна 
                 строка; если n=0, то возврат в начало текущей строки.

     TAB n     Пропуск n колонок (перемещение назад, если вы задали отридца-
               тельное число). "Колонка" в данном контексте означает позицию 
               печати, но не колонку таблицы.


                                   -- 125 --



     LE[FT],   Выравнивание влево, центрирование, выравнивание 
     CE[NTER], вправо данных в текущей строке. CENTER и RIGHT 
     R[IGHT]   используют значение SET LINESIZE для вычисления позиции, в 
               которую необходимо поместить данные.

     BOLD      Печатает данные полужирным шрифтом.  SQL*PLUS показывает 
               полужирную печать на терминале повторением данных на трех 
               последовательных строках.

     FORMAT char Задает модель формата, которая определяет формат для 
 последующих элементов данных. Модель формата должна быть симольной 
 константой, такой как А10 или $999- но не переменной. Подробнее о моделях 
 смотри COLUMN FORMAT.

    Если тип данных модели формата не соответствует типу элемента данных, 
 фраза FORMAT не оказывает влияния на данный элемент.

    Если данное несоответсвие обнаружено, то SQL*PLUS печатает числовые 
 значения, используя формат по умолчанию для числовых значений или формат 
 заданный фразой SET NUMFORMAT. Данные типа DATE выводятся в формате по 
 умолчанию.

    Подробнее о форматах по умолчанию смотри описание фразы FORMAT команды 
COLUMN в данной главе.

Рекомендации   SQL*PLUS интерпретирует TTITLE в новом формате, если 
               допустимая фраза printspec (LEFT, SKIP, COL, и т.д.) следует 
               непосредственно за именем команды.  Смотри описание COLUMN 
               NEW_VALUE для печати колонок и дат в верхнем заголовке.

               Вы можете использовать любое количество констант и переменных 
               в printspec. SQL*PLUS будет выводить константы и переменные в 
               указанном вами порядке, позиционируя и форматируя каждую 
               константу и переменную в соответсвии с предшествующей фразой 
               printspec.

     Примеры   Чтобы определить верхний заголовок: "Monthly Analysis" 
               выравненным влево, дату по центру и справа номер страницы, и 
               вывести "Date in Thousands" полужирным шрифтом в центре 
               следующей строки, введите:

               SQL> TTITLE LEFT 'Monthly Analysis' CENTER '11 Mar 88' -
               > RIGHT 'Page:' FORMAT 999 SQL.PNO SKIP CENTER
               BOLD -
               > 'Data in Thousands'

               В результате будет следующий заголовок:

               Monthly Analysis       11 Mar 88
               Page:   1 Data in Thousands

               Чтобы подавить вывод заголовка без изменения его описания, 
               введите:

               SQL> TTITLE OFF




                                   -- 126 --



        UNDEFINE

          Цель Уничтожает переменную пользователя, которую вы создали явно 
               (командой DEFINE) или неявно (с помощью аргументов команды 
               START).

     Синтаксис UNDEF[INE] переменная

Термины и Фразы     переменная          Имя переменной пользователя, которую 
                                        вы хотите удалить.

     Примеры   Для удаление переменной с именем POS, введите:

               SQL> UNDEFINE POS













































                                   -- 127 --



        WHENEVER SQLERROR

          Цель Покидает SQL*PLUS, если команда SQL или блок PL/SQL 
               сгенерировали ошибку.

     Синтаксис WHENEVER SQLERROR {EXIT [SUCCESS | FAILURE | WARNING | n | 
                              переменная] | CONTINUE}

Термины и Фразы     EXIT [SUCCESS|FAILURE|WARNING|n|переменная]
          Приказывает SQL*PLUSу совершить отложенные изменения в БД и выйти, 
         как только SQL*PLUS обнаружит любую SQL-ошибку (но только после 
         вывода сообщения об ошибке). Фраза EXIT данной команды имеет 
         синтаксис аналогичный команде EXIT. Смотри описание команды EXIT.

          Если ошибки не произошло, то выхода из SQL*PLUS не будет.

CONTINUE  Выключает опцию EXIT.

Примеры   Следующая команда из командного файла обеспечивает выход из 
       SQL*PLUS и вывод кода ошибки SQL, если команда SQL UPDATE завершится 
       неудачно, т.е. таким образом будет пропущена команда COPY:

          SQL> GET RAISE
            1  WHENEVER SQLERROR EXIT SQL.SQLCODE
            2  UPDATE EMP SET SAL = SAL*1.1
            3  COPY TO SCOTT/TIGER@D:BETHESDA -
            4  REPLACE EMP -
            5  USING SELECT * FROM EMP
            6  WHENEVER SQLERROR CONTINUE






























                                   -- 128 --




Приложение А      Сообщения об ошибках      Команды COPY


          В приложении А приводится список сообщений об ошибках команды 
       COPY. Сообщения об ошибках, генерируемых ORACLE RDBMS, смотри 
       в "Руководство по кодам и сообщениям об ошибках ORACLE".


CPY0002:  Незаконная или ошибочная опция APPEND,CREATE,INSERT или REPLACE

Причина:  Внутренняя функция COPY активизировала COPY со значением опциии 
          создания вне диапазона.

Действие: Обратитесь к представителю фирмы ORACLE.


CPY0003:  Internal Error: logical host number out of range Внутренняя ошибка: 
       логический номер хоста вне диапазона

Причина:  Внутреняя функция COPY активизаровалась со значением логического 
       номера хоста, который является вне диапазона.

Действие: Обратитесь к представителю фирмы ORACLE.

CPY0004:  Исходная и целевая таблицы и имена колонок несопоставимы.

Причина:  В операции APPEND или INSERT (когда таблица существует) по крайней 
       мере имя одной колонки в таблице-назначения не совпадает с 
       соответствующим именем колонки в необязательном списке имен колонок 
       или в команде SELECT.

Действие: Исправьте команду COPY, убедитесь, что имена колонок и их 
       последовательность в таблице назначения совпадает с именами и 
       последовательностью колонок в необязательном списке колонок или 
       команде SELECT.


CPY0005:  Source and destination column attributes don't match Атрибуты 
       колонок в целевой и исходной таблицах не совпадают

Причина:  В операции APPEND или INSERT (когда таблица существует), по крайней 
       мере одна колонка в таблице-назначения не совпадает с типом 
       соответсвующей колонки в команде SELECT.

Действие: Исправьте команду COPY, убедитесь, что типы колонок совпадают.  Для 
       преобразования данных можно использовать TO_DATE, TO_CHAR, TO_NUMBER.


CPY0006:  Select list has more columns than destination table В списке выбора 
       колонок больше, чем в целевой таблице

Причина:  В операции APPEND или INSERT (когда таблица существует), количество 
       колонок в команде SELECT больше, чем количество колонок в целевой 
       таблице.

Действие: Исправьте команду COPY, убедитесь, что количество выбираемых 
       колонок равно количеству колонок в целевой таблице.

                                   -- 129 --




CPY0007:  Select list has fewer columns than destination table В списке 
       выбора колонок меньше, чем в целевой таблице

Причина:  В операции APPEND или INSERT (когда таблица существует), количество 
       колонок в команде SELECT меньше, чем количество колонок в целевой 
       таблице.

Действие: Исправьте команду COPY, убедитесь, что количество выбираемых 
       колонок равно количеству колонок в целевой таблице.


CPY0008:  More column list names than columns in the destination table Больше 
       имен в списке колонок, чем в целевой таблице

Причина:  В операции APPEND или INSERT (когда таблица существует), количество 
       колонок в имен колонок больше, чем количество колонок в целевой 
       таблице.

Действие: Исправьте команду COPY, убедитесь, что количество колонок в списке 
       колонок равно количеству колонок в целевой таблице.


CPY0009:   Fewer column list names than columns in the destination table 
       Меньше имен в списке колонок, чем в целевой таблице

Причина:  В операции APPEND или INSERT (когда таблица существует), количество 
       колонок в имен колонок меньше, чем количество колонок в целевой 
       таблице.

Действие: Исправьте команду COPY, убедитесь, что количество колонок в списке 
       колонок равно количеству колонок в целевой таблице.



























                                   -- 130 --



        Приложение B 
                          Версия 3.0       Усовершенствования

SQL*PLUS версии 3.0 предоставляет пользователю следующие возможности:

*    Вы можете определить, будет ли SQL*PLUS запоминать команды COMMIT и 
     ROLLBACK в буффере SQL. Новая SET-переменная, COMPATIBILITY, позволяет 
     вам поддерживать совместимость с командными файлами, написанными для 
     ORACLE версии 5. Смотри описание переменной COMPATIBILITY команды SET в 
     главе 6.

*    Вы можете вводить, редактировать, запоминать и выполнять блоки PL/SQL из 
     SQL*PLUSа. Смотри подраздел "Выполнение блоков PL/SQL" раздела "Ввод и 
     выполнение команд" в главе 2.

*    Вы автоматически ощутите улучшение работы в сетевой среде. SQL*PLUS 
     сейчас определяет несколько колонок в команде SELECT с помощью одного 
     сетевого сообщения.

*    Вы можете ограничить доступ пользователей к множеству команд SQL*PLUS и 
     SQL с помощью таблицы PRODUCT_USER_PROFILE, расположенной в бюджете 
     SYSTEM. Полное объяснение смотри в приложении Е.

*    Вы можете опускать пароль во фразах FROM и TO команды COPY; SQL*PLUS 
     попросит вас ввести пароль, подавив при этом вывод пароля на экран. 
     Смотри описание команды COPY в главе 6.

































                                   -- 131 --



     Приложение C
                          Ограничения SQL*PLUS


Таблица С-1, на следующей странице, приводит ограничения или максимальные 
значения для каждого приведенного элемента SQL*PLUS. Приведенные ограничения 
верны для большинства операционных систем (кроме PDP11 и mc68000).

Таблица С-1              Элемент
Ограничение Ограничения SQL*PLUS 
------------------------------------------------------
 длина имени файла зависит от системы

длина имени пользователя      30 символов

длина имени переменной пользователя 30 символов

длина переменной пользователя      240 символов

количество переменных пользователя 1024

количество переменных в команде    50 SQL INSERT списке INTO

количество переменных в команде SQL 100

длина командной строки             500 символов

длина LONG-значения введенного     250 символов в SQL*PLUS

длина выводной строки              500 символов (миним длина 5)

длина строки после подстановки     1000 переменных

количество строк на одну команду   500 SQL (строка=80 симв)

количество строк на странице       50000

общая длина записи            60000 символов для VMS, иначе 32767

Количество записей в массиве       5000 выборки

количество вложенных командных     20 для VMS,CMS, файлов Unix; иначе 5

количество страниц            99999















                                   -- 132 --




            Приложение D                        Список команд SQL

В таблице D-1, на следующей странице, приводятся основные команды и фразы 
SQL. Команды SQL описаны в данном руководстве. За полной документацией по 
этим командам обратитесь к "Руководство пользователя по языку SQL" и 
"Справочное руководство по языку SQL".

Таблица D-1              Основные команды и фразы SQL
Список команд SQL
----------------------------------------------------
                    ALTER               GROUP BY
                    AUDIT               HAVING
                    CLOSE Cursor   INSERT
                    COMMENT        LOCK TABLE
                    COMMIT         NOAUDIT
                    CONNECT        OPEN Cursor
                    CONNECT BY          ORDER BY
                    CREATE         PREPARE
                    DECLARE        RENAME
                    DELETE         REVOKE
                    DESCRIBE       ROLLBACK
                    DROP           SAVEPOINT
                    EXECUTE        SELECT
                    EXPLAIN        SET TRANSACTION
                    FETCH               UPDATE
                    FOR            VALIDATE INDEX
                    FROM           WHENEVER
                    GRANT               WHERE






























                                   -- 133 --




        Приложение E
                     Ограничение привилегий пользователя в SQL*PLUS

В приложении Е описывается использование таблицы PRODUCT_USER_PROFILE в 
SQL*PLUS. Различные продукты ORACLE используют PRODUCT_USER_PROFILE, таблица 
в счете (account) SYSTEM, для того, чтобы обеспечить защиту на уровне 
продукта, которая дополняет защиту на уровне пользователя, которая в свою 
очередь обеспечивается командами SQL GRANT и REVOKE. ДБА может использовать 
PRODUCT_USER_PROFILE для запрещения определенных команд SQL*PLUS и SQL в 
среде SQL*PLUS для каждого пользователя. Заметим, что SQL*PLUS- но не ORACLE 
RDBMS- необязательно использует данный метод безопасности.

Вы можете использовать PRODUCT_USER_PROFILE в ваших собственных разработках, 
также как ее используют продукты ORACLE. Данное приложения объясняет 
спицифику использования PRODUCT_USER_PROFILE SQL*PLUSом и также приводит 
набор правил по использованию данной таблицы в других целях. Обратитесь к ДБА 
за информацией по доступу к PRODUCT_USER_PROFILE.

Если вы ограничили привилегии пользователя командами GRANT и REVOKE, но не 
ограничили данные привилегии в PRODUCT_USER_PROFILE, ограничения будут 
действовать.  Если вы запретили пользователю использовать некоторые команды с 
помощью таблицы PRODUCT_USER_PROFILE, но не ограничили данный доступ 
командами GRANT или REVOKE, запрет будет действовать.

Вы можете создать PRODUCT_USER_PROFILE, выполнив командный файл с именем 
PUPBLD.SQL .  Расширение и местоположение файла зависит от системы. Смотри 
руководство по установке ORACLE для вашей операционной системы или обратитесь 
к вашему ДБА.

SQL*PLUS читает ограничения из PRODUCT_USER_PROFILE, когда пользователь 
регистрируется в SQL*PLUS и поддерживает данные ограничения в течение сеанса.  
Изменения в таблице PRODUCT_USER_PROFILE будут действовать только при новой 
регистрации пользователя в SQL*PLUS.

Структура таблицы
               Таблица состоит из следующих колонок:

               Имя                  Null ?   Type
               ------------------------ -------- -------------
               PRODUCT              NOT NULL CHAR(30)
               USERID                       CHAR(30)
               ATTRIBUTE                    CHAR(240)
               SCOPE                             CHAR(240)
               NUMERIC_VALUE                NUMBER(15,2)
               CHAR_VALUE                        CHAR(240)
               DATE_VALUE                        DATE

Описание и использование колонок

Опишем каждую колонку таблицы PRODUCT_USER_PROFILE:

Product        Должна содержать имя продукта (в данном случае SQL*PLUS). Вы 
              не можете вводить универсальное сопоставление (wildcard) в 
              данную колонку. Вы также не можете вводить NULL.




                                   -- 134 --



Userid         Должна содержать имя пользователя (на верхнем регистре), 
              которому вы хотите запретить использование команды. Чтобы 
              запретить использование команды более чем одному пользователю, 
              испльзуйте обобщенный символ SQL (%) или сделайте несколь 
              записей. Таким образом, следующие записи верны:
               *  SCOTT
               *  CLASS1
               *  CLASS%  (все пользователи, чьи имена начинаются с CLASS)
               *  %      (все пользователи)

Attribute      Должна содержать имя (на верхнем регистре) команды SQL*PLUS 
              или SQL, которую вы хотите запретить использовать (например, 
              GET). Вы не можете вводить обобщенный символ. Смотри 
              "Управление", ниже, где приводится список команд SQL*PLUS и 
              SQL, которые вы можете запрещать.

Scope         SQL*PLUS игнорирует данную колонку.  Рекомендуется вводить NULL 
              в данную колонку.  Другие продукты могут сохранить в ней 
              ограничения по спец-файлам или иные данные.

Numeric_Value  SQL*PLUS игнорирует данную колонку.  Рекомендуется вводить 
              NULL в данную колонку.  Другие продукты могут сохранять в 
              данной колонке цифровые значения.

Char_Value    Должна содержать символьную строку "DISABLED". Нельзя 
              использовать обобщенный символ.

Date_Value    SQL*PLUS игнорирует данную колонку.  Рекомендуется вводить NULL 
              в данную колонку.  Другие продукты могут сохранять 
              DATE-значения в данной колонке.

Управление
   Администратор БД пользователь SYSTEM владеет и имеет все привилегии для 
таблицы PRODUCT_USER_PROFILE. (Когда SYSTEM регистрируется, SQL*PLUS не 
читает PRODUCT_USER_PROFILE. Поэтому, на пользователя SYSTEM не накладывается 
никаких ограничений).  Другие пользователи ORACLE должны иметь доступ только 
на выбор из данной таблицы. Комндный файл PUPBLD, когда он выполняется, 
предоставляет SELECT-доступ к PRODUCT_USER_PROFILE всем пользователям. Чтобы 
запретить команду SQL*PLUS или SQL указанному пользователю, вставьте строку 
содержащую имя пользователя в колонке Userid, имя команды в колонке 
Attribute, и DISABLED в колонке Char_Value. Колонки Scope, Numeric_Value, 
Date_Value должны содержать NULL. Например:

                           NUMERIC CHAR     DATE
PRODUCT  USERID ATTRIBUTE SCOPE VALUE   VALUE VALUE 
-------- ------ --------- ----- ------- -------- ----- 
SQL*Plus SCOTT  HOST DISABLED 
SQL*Plus %         INSERT DISABLED 
SQL*Plus %         
UPDATE DISABLED SQL*Plus %         DELETE DISABLED

Чтобы разрешить вновь пользоваться командой, удалите строку содержащую 
ограничение.

Вы можете запретить следующие команды SQL*PLUS:
     * CONNECT
     * EDIT
     * EXIT

                                   -- 135 --



     * GET
     * HOST  (или алиас команды HOST, такой как $)
     * QUIT
     * RUN
     * SAVE
     * SPOOL
     * START

Вы также можете запретить следующие команды SQL:

     * ALTER
     * AUDIT
     * CONNECT
     * CREATE
     * DELETE
     * DROP
     * GRANT
     * INSERT
     * LOCK
     * NOAUDIT
     * RENAME
     * REVOKE
     * SELECT
     * UPDATE
     * VALIDATE


































                                   -- 136 --




        Приложение F             Команды SQL*PLUS  ранних версий

          В приложение F приведены команды SQL*PLUS более ранних версий. 
          Данные "старые" команды все еще работают в SQL*PLUS, но в SQL*PLUS 
          существуют новые команды, которые более функционально 
          усовершенствованы.


BTITLE (старая форма)

     Назначение     Выводит заголовок внизу каждой страницы отчета.
      Синтаксис     BTI[TLE] текст

    Рекомендации    Старая форма BTITLE предлагает более ограниченные 
               возможности по форматированию, чем новая форма команды, но 
               обеспечивает совместимость с UFI (предшественник SQL*PLUS). 
               Старая форма команды описывает нижний заголовок состоящий из 
               пустой строки и строки с отцентрированным текстом. За 
               подробностями обратитесь к описанию TTITLE (старая форма) в 
               данном прилоджении.


COLUMN DEFAULT

     Назначение     Сбрасывает атрибуты вывода указанных колонок к их 
значениям по умолчанию.

      Синтаксис     COL[UMN] {колонка | выражение} DEF[AULT]
    Рекомендации    Действует аналогично COLUMN CLEAR


DOCUMENT

     Назначение     Начинает блок документирования в командном файле.
      Синтаксис     DOC[UMENT]

   Рекомендации За информацией по данному методу документирования командных 
файлов обратитесь к подразделу "Размещение комментариев в командных файлах" 
раздела "Сохранение команд для более позднего исрользования" в главе 3 и к 
REMARK в главе 6.

После ввода DOCUMENT и нажатия [Return], SQL*PLUS выведет подсказку DOC> 
вместо SQL>, пока вы не закончите документирование. Знак "#" заканчивает 
документирование.  Если вы установили DOCUMENT в OFF, SQL*PLUS проигнорирует 
команду DOCUMENT и интерпретирует набор строк документирования как команды. 
(Смотри SET DOCUMENT в данном приложении.)


NEWPAGE

     Назначение     Выводит в буфферный вывод n строк до начала следующей 
                    страницы.

      Синтаксис     NEWPAGE [1 | n]

    Рекомендации    За информацией обратитесь к описанию переменной NEWPAGE 
                     команды SET в главе 6.

                                   -- 137 --




SET BUFFER

     Назначение     Делает указанный буффер текущим.

      Синтаксис     SET BUF[FER] {буффер | SQL}

    Рекомендации
    Сначала, текущим является буффер SQL.  SQL*PLUS не требует использования 
нескольких буфферов; один буффер SQL позволяет сделать все необходимое.

Если имя буффера, которое вы указали, пока не существует, SET BUFFER 
определит (создаст и назовет) данный буффер. SQL*PLUS удалит буффер и его 
содержимое при выходе из SQL*PLUSа.

Выполнение запроса автоматически делает SQL-буффер текущим. Чтобы скопировать 
содержимое буффера в другой буффер, используйте команды GET и SAVE.  Чтобы 
очистить текущий буффер, используйте CLEAR BUFFER. Чтобы очистить SQL-буффер, 
когда он не является текущим, используйте CLEAR SQL.


SET DOCUMENT

     Назначение     Разрешает или запрещает команду DOCUMENT.
      Синтаксис     SET DOC[UMENT] {OFF | ON}

    Рекомендации    SET DOCUMENT ON разрешает использование команды DOCUMENT.  
               SET DOCUMENT OFF запрещает использование данной команды. Если 
               вы запретили использование DOCUMENT, SQL*PLUS интерпретирует 
               последующие строки как команды.

               Смотри описание команды DOCUMENT в данном приложении.

SET TRUNCATE

     Назначение     Упраляет сверткой или отсечением элементов данных, длина 
                    которых больше текущей ширины строки.
      Синтаксис     SET TRU[NCATE] {OFF | ON}

    Рекомендации    Функция ON аналогична SET WRAP OFF, и наоборот. Вы можете 
предпочесть использование WRAP, так как команда SHOW опзнает WRAP, и не 
распознает TRUNCATE.


TTITLE (старая форма)

     Назначение     Выводит заголовок вверху каждой страницы отчета.
      Синтаксис     TTI[TLE] текст

    Рекомендации    Старая форма TTITLE предлагает более ограниченные 
возможности по форматированию, чем новая форма команды, но обеспечивает 
совместимость с UFI (предшественник SQL*PLUS).  Старая форма команды 
описывает верхний заголовок состоящий из строки с датой слева и номером 
страницы справа, на второй строке отцентрированный текст, третья строка- 
пустая.

"текст", который вы указали, задает заголовок, который будет выводиться на 
второй строке.

                                   -- 138 --



SQL*PLUS центрирует текст исходя из установленной длины строки (SET 
LINESIZE). Символ разделитель (|) начинает новую строку; два символа "||" 
означают вставку пустой строки. Можно задать новый символ разделитель строк с 
помощью SET HEADSEP.

Вы можете управлять форматированием номеров страниц в старых формах команд 
TTITLE и BTITLE, определив переменную с именем "_page". По умолчанию она 
имеет значение "page &P4". Чтобы изменить формат, вы можете использовать 
DEFINE _page с новым форматом:

SQL> SET ESCAPE /
SQL> DEFINE _page = 'Page /&P2'

Данная строка форматирования будет выводить "Page" и далее двухсимвольный 
номер страницы. Вы должны обязательно escape-символ, стобы SQL*PLUS не 
интерпретировал амперсанд (&) как подстановочную переменную. Смотри описание 
переменной ESCAPE команды SET в главе 6.

SQL*PLUS интерпретирует TTITLE в старом формате, если сразу за именем команды 
не следует фраза из нового формата команды.

     Примеры   Чтобы используя TTITLE в старом формате, установить верхний 
заголовок с датой слева, номером листа справа и на новой строке текст "SALES 
DEPARTMENT" и на следующей строке "PERSONNEL REPORT", введите:

        SQL> TTITLE 'SALES DEPARTMENT|PERSONNEL REPORT'

KOAP Open Portal 2000