天天看點

Oracle的SQL*PLUS指令的使用大全

  Oracle的sql*plus是與oracle進行互動的用戶端工具。在sql*plus中,可以運作sql*plus指令與sql*plus語句。

  

  我們通常所說的DML、DDL、DCL語句都是sql*plus語句,它們執行完後,都可以儲存在一個被稱為sql buffer的記憶體區域中,并且隻能儲存一條最近執行的sql語句,我們可以對儲存在sql buffer中的sql 語句進行修改,然後再次執行,sql*plus一般都與資料庫打交道。

  

  除了sql*plus語句,在sql*plus中執行的其它語句我們稱之為sql*plus指令。它們執行完後,不儲存在sql buffer的記憶體區域中,它們一般用來對輸出的結果進行格式化顯示,以便于制作報表。

  

  下面就介紹一下一些常用的sql*plus指令:

  

  1. 執行一個SQL腳本檔案

  SQL>start file_name

  SQL>@ file_name

  我們可以将多條sql語句儲存在一個文本檔案中,這樣當要執行這個檔案中的所有的sql語句時,用上面的任一指令即可,這類似于dos中的批處理。

  

  2. 對目前的輸入進行編輯

  SQL>edit

  

  3. 重新運作上一次運作的sql語句

  SQL>/

  

  4. 将顯示的内容輸出到指定檔案

  SQL> SPOOL file_name

  在螢幕上的所有内容都包含在該檔案中,包括你輸入的sql語句。

  

  5. 關閉spool輸出

  SQL> SPOOL OFF

  隻有關閉spool輸出,才會在輸出檔案中看到輸出的内容。

  

  6.顯示一個表的結構

  SQL> desc table_name

  

  7. COL指令:

  主要格式化列的顯示形式。

  該指令有許多選項,具體如下:

  COL[UMN] [{ column|expr} [ option ...]]

  Option選項可以是如下的子句:

  ALI[AS] alias

  CLE[AR]

  FOLD_A[FTER]

  FOLD_B[EFORE]

  FOR[MAT] format

  HEA[DING] text

  JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}

  LIKE { expr|alias}

  NEWL[INE]

  NEW_V[ALUE] variable

  NOPRI[NT]|PRI[NT]

  NUL[L] text

  OLD_V[ALUE] variable

  ON|OFF

  WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]

  

  1). 改變預設的列标題

  COLUMN column_name HEADING column_heading

  For example:

  Sql>select * from dept;

  DEPTNO DNAME            LOC

  ---------- ---------------------------- ---------

  10 ACCOUNTING          NEW YORK

  sql>col LOC heading location

  sql>select * from dept;

  DEPTNO DNAME            location

  --------- ---------------------------- -----------

  10 ACCOUNTING          NEW YORK

  

  2). 将列名ENAME改為新列名EMPLOYEE NAME并将新列名放在兩行上:

  Sql>select * from emp

  Department name      Salary

  ---------- ---------- ----------

  10 aaa        11

  SQL> COLUMN ENAME HEADING ’Employee|Name’

  Sql>select * from emp

  Employee

  Department name      Salary

  ---------- ---------- ----------

  10 aaa        11

  note: the col heading turn into two lines from one line.

  

  3). 改變列的顯示長度:

  FOR[MAT] format

  Sql>select empno,ename,job from emp;

  EMPNO ENAME   JOB

  ---------- ----------   ---------

  7369 SMITH   CLERK

  7499 ALLEN   SALESMAN

  7521 WARD    SALESMAN

  Sql> col ename format a40

  EMPNO ENAME                  JOB

  ----------  ----------------------------------------     ---------

  7369 SMITH                  CLERK

  7499 ALLEN                  SALESMAN

  7521 WARD                  SALESMAN

  

  4). 設定列标題的對齊方式

  JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}

  SQL> col ename justify center

  SQL> /

  EMPNO      ENAME          JOB

  ----------  ----------------------------------------    ---------

  7369 SMITH                  CLERK

  7499 ALLEN                  SALESMAN

  7521 WARD                   SALESMAN

  對于NUMBER型的列,列标題預設在右邊,其它類型的列标題預設在左邊

  

  5). 不讓一個列顯示在螢幕上

  NOPRI[NT]|PRI[NT]

  SQL> col job noprint

  SQL> /

  EMPNO      ENAME

  ----------   ----------------------------------------

  7369 SMITH

  7499 ALLEN

  7521 WARD

  

  6). 格式化NUMBER類型列的顯示:

  SQL> COLUMN SAL FORMAT $99,990

  SQL> /

  Employee

  Department Name    Salary  Commission

  ---------- ---------- --------- ----------

  30     ALLEN    $1,600  300

  

  7). 顯示列值時,如果列值為NULL值,用text值代替NULL值

  COMM NUL[L] text

  SQL>COL COMM NUL[L] text

  

  8). 設定一個列的回繞方式

  WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]

  COL1

  --------------------

  HOW ARE YOU?

  

  SQL>COL COL1 FORMAT A5

  SQL>COL COL1 WRAPPED

  COL1

  -----

  HOW A

  RE YO

  U?

  

  SQL> COL COL1 WORD_WRAPPED

  COL1

  -----

  HOW

  ARE

  YOU?

  

  SQL> COL COL1 WORD_WRAPPED

  COL1

  -----

  HOW A

  

  9). 顯示列的目前的顯示屬性值

  SQL> COLUMN column_name

  

  10). 将所有列的顯示屬性設為預設值

  SQL> CLEAR COLUMNS

  

  8. 屏蔽掉一個列中顯示的相同的值

  BREAK ON break_column

  SQL> BREAK ON DEPTNO

  SQL> SELECT DEPTNO, ENAME, SAL

  FROM EMP

  WHERE SAL < 2500

  ORDER BY DEPTNO;

  DEPTNO   ENAME     SAL

  ---------- ----------- ---------

  10      CLARK    2450

  MILLER   1300

  20      SMITH    800

  ADAMS    1100

  

  9. 在上面屏蔽掉一個列中顯示的相同的值的顯示中,每當列值變化時在值變化之前插入n個空行。

  BREAK ON break_column SKIP n

  

  SQL> BREAK ON DEPTNO SKIP 1

  SQL> /

  DEPTNO ENAME SAL

  ---------- ----------- ---------

  10 CLARK 2450

  MILLER 1300

  

  20 SMITH 800

  ADAMS 1100

  

  10. 顯示對BREAK的設定

  SQL> BREAK

  

  11. 删除6、7的設定

  SQL> CLEAR BREAKS

  

  12. Set 指令:

  該指令包含許多子指令:

  SET system_variable value

  system_variable value 可以是如下的子句之一:

  APPI[NFO]{ON|OFF|text}

  ARRAY[SIZE] {15|n}

  AUTO[COMMIT]{ON|OFF|IMM[EDIATE]|n}

  AUTOP[RINT] {ON|OFF}

  AUTORECOVERY [ON|OFF]

  AUTOT[RACE] {ON|OFF|TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]

  BLO[CKTERMINATOR] {.|c}

  CMDS[EP] {;|c|ON|OFF}

  COLSEP {_|text}

  COM[PATIBILITY]{V7|V8|NATIVE}

  CON[CAT] {.|c|ON|OFF}

  COPYC[OMMIT] {0|n}

  COPYTYPECHECK {ON|OFF}

  DEF[INE] {&|c|ON|OFF}

  DESCRIBE [DEPTH {1|n|ALL}][LINENUM {ON|OFF}][INDENT {ON|OFF}]

  ECHO {ON|OFF}

  EDITF[ILE] file_name[.ext]

  EMB[EDDED] {ON|OFF}

  ESC[APE] {/|c|ON|OFF}

  FEED[BACK] {6|n|ON|OFF}

  FLAGGER {OFF|ENTRY |INTERMED[IATE]|FULL}

  FLU[SH] {ON|OFF}

  HEA[DING] {ON|OFF}

  HEADS[EP] {||c|ON|OFF}

  INSTANCE [instance_path|LOCAL]

  LIN[ESIZE] {80|n}

  LOBOF[FSET] {n|1}

  LOGSOURCE [pathname]

  LONG {80|n}

  LONGC[HUNKSIZE] {80|n}

  MARK[UP] HTML [ON|OFF] [HEAD text] [BODY text] [ENTMAP {ON|OFF}] [SPOOL

  {ON|OFF}] [PRE[FORMAT] {ON|OFF}]

  NEWP[AGE] {1|n|NONE}

  NULL text

  NUMF[ORMAT] format

  NUM[WIDTH] {10|n}

  PAGES[IZE] {24|n}

  PAU[SE] {ON|OFF|text}

  RECSEP {WR[APPED]|EA[CH]|OFF}

  RECSEPCHAR {_|c}

  SERVEROUT[PUT] {ON|OFF} [SIZE n] [FOR[MAT] {WRA[PPED]|WOR[D_

  WRAPPED]|TRU[NCATED]}]

  SHIFT[INOUT] {VIS[IBLE]|INV[ISIBLE]}

  SHOW[MODE] {ON|OFF}

  SQLBL[ANKLINES] {ON|OFF}

  SQLC[ASE] {MIX[ED]|LO[WER]|UP[PER]}

  SQLCO[NTINUE] {> |text}

  SQLN[UMBER] {ON|OFF}

  SQLPRE[FIX] {#|c}

  SQLP[ROMPT] {SQL>|text}

  SQLT[ERMINATOR] {;|c|ON|OFF}

  SUF[FIX] {SQL|text}

  TAB {ON|OFF}

  TERM[OUT] {ON|OFF} 用于控制SQL教本的輸出,其預設值為ON.當時用預設值時,如果SQL腳本有輸出結果則會在螢幕上顯示出結果。反之不成

  TI[ME] {ON|OFF}  在SQL提示符前是否顯示系統時間

  TIMING 用于設定是否要顯示SQL語句執行時間,預設值為OFF,表示不會顯示

         SHOW RECYCLEBIN Oracle新增的指令 用于顯示在資料庫資源回收筒中的目前使用者對象