熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> Oracle >> 正文

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

2013-11-13 15:40:20  來源: Oracle 

  Oracle的sql*plus是與oracle進行交互的客戶端工具在sql*plus中可以運行sql*plus命令與sql*plus語句
  
  我們通常所說的DMLDDLDCL語句都是sql*plus語句它們執行完後都可以保存在一個被稱為sql buffer的內存區域中並且只能保存一條最近執行的sql語句我們可以對保存在sql buffer中的sql 語句進行修改然後再次執行sql*plus一般都與數據庫打交道
  
  除了sql*plus語句在sql*plus中執行的其它語句我們稱之為sql*plus命令它們執行完後不保存在sql buffer的內存區域中它們一般用來對輸出的結果進行格式化顯示以便於制作報表
  
  下面就介紹一下一些常用的sql*plus命令
  
   執行一個SQL腳本文件
  SQL>start file_name
  SQL>@ file_name
  我們可以將多條sql語句保存在一個文本文件中這樣當要執行這個文件中的所有的sql語句時用上面的任一命令即可這類似於dos中的批處理
  
   對當前的輸入進行編輯
  SQL>edit
  
   重新運行上一次運行的sql語句
  SQL>/
  
   將顯示的內容輸出到指定文件
  SQL> SPOOL file_name
  在屏幕上的所有內容都包含在該文件中包括你輸入的sql語句
  
   關閉spool輸出
  SQL> SPOOL OFF
  只有關閉spool輸出才會在輸出文件中看到輸出的內容
  
  .顯示一個表的結構
  SQL> desc table_name
  
   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]
  
  ) 改變缺省的列標題
  COLUMN column_name HEADING column_heading
  For example:
  Sql>select * from dept;
  DEPTNO DNAME            LOC
  
   ACCOUNTING          NEW YORK
  sql>col LOC heading location
  sql>select * from dept;
  DEPTNO DNAME            location
  
   ACCOUNTING          NEW YORK
  
  ) 將列名ENAME改為新列名EMPLOYEE NAME並將新列名放在兩行上
  Sql>select * from emp
  Department name      Salary
  
   aaa        
  SQL> COLUMN ENAME HEADING Employee|Name
  Sql>select * from emp
  Employee
  Department name      Salary
  
   aaa        
  note: the col heading turn into two lines from one line
  
  ) 改變列的顯示長度
  FOR[MAT] format
  Sql>select empnoenamejob from emp;
  EMPNO ENAME   JOB
     
   SMITH   CLERK
   ALLEN   SALESMAN
   WARD    SALESMAN
  Sql> col ename format a
  EMPNO ENAME                  JOB
        
   SMITH                  CLERK
   ALLEN                  SALESMAN
   WARD                  SALESMAN
  
  ) 設置列標題的對齊方式
  JUS[TIFY] {L[EFT]|C[ENTER]|C[ENTRE]|R[IGHT]}
  SQL> col ename justify center
  SQL> /
  EMPNO      ENAME          JOB
       
   SMITH                  CLERK
   ALLEN                  SALESMAN
   WARD                   SALESMAN
  對於NUMBER型的列列標題缺省在右邊其它類型的列標題缺省在左邊
  
  ) 不讓一個列顯示在屏幕上
  NOPRI[NT]|PRI[NT]
  SQL> col job noprint
  SQL> /
  EMPNO      ENAME
    
   SMITH
   ALLEN
   WARD
  
  ) 格式化NUMBER類型列的顯示
  SQL> COLUMN SAL FORMAT $
  SQL> /
  Employee
  Department Name    Salary  Commission
  
       ALLEN    $  
  
  ) 顯示列值時如果列值為NULL值用text值代替NULL值
  COMM NUL[L] text
  SQL>COL COMM NUL[L] text
  
  ) 設置一個列的回繞方式
  WRA[PPED]|WOR[D_WRAPPED]|TRU[NCATED]
  COL
  
  HOW ARE YOU?
  
  SQL>COL COL FORMAT A
  SQL>COL COL WRAPPED
  COL
  
  HOW A
  RE YO
  U?
  
  SQL> COL COL WORD_WRAPPED
  COL
  
  HOW
  ARE
  YOU?
  
  SQL> COL COL WORD_WRAPPED
  COL
  
  HOW A
  
  ) 顯示列的當前的顯示屬性值
  SQL> COLUMN column_name
  
  ) 將所有列的顯示屬性設為缺省值
  SQL> CLEAR COLUMNS
  
   屏蔽掉一個列中顯示的相同的值
  BREAK ON break_column
  SQL> BREAK ON DEPTNO
  SQL> SELECT DEPTNO ENAME SAL
  FROM EMP
  WHERE SAL <
  ORDER BY DEPTNO;
  DEPTNO   ENAME     SAL
  
        CLARK    
  MILLER   
        SMITH   
  ADAMS   
  
   在上面屏蔽掉一個列中顯示的相同的值的顯示中每當列值變化時在值變化之前插入n個空行
  BREAK ON break_column SKIP n
  
  SQL> BREAK ON DEPTNO SKIP
  SQL> /
  DEPTNO ENAME SAL
  
   CLARK
  MILLER
  
   SMITH
  ADAMS
  
   顯示對BREAK的設置
  SQL> BREAK
  
   刪除的設置
  SQL> CLEAR BREAKS
  
   Set 命令
  該命令包含許多子命令
  SET system_variable value
  system_variable value 可以是如下的子句之一
  APPI[NFO]{ON|OFF|text}
  ARRAY[SIZE] {|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]{V|V|NATIVE}
  CON[CAT] {|c|ON|OFF}
  COPYC[OMMIT] {|n}
  COPYTYPECHECK {ON|OFF}
  DEF[INE] {&|c|ON|OFF}
  DESCRIBE [DEPTH {|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] {|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] {|n}
  LOBOF[FSET] {n|}
  LOGSOURCE [pathname]
  LONG {|n}
  LONGC[HUNKSIZE] {|n}
  MARK[UP] HTML [ON|OFF] [HEAD text] [BODY text] [ENTMAP {ON|OFF}] [SPOOL
  {ON|OFF}] [PRE[FORMAT] {ON|OFF}]
  NEWP[AGE] {|n|NONE}
  NULL text
  NUMF[ORMAT] format
  NUM[WIDTH] {|n}
  PAGES[IZE] {|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}
  TI[ME] {ON|OFF}
  TIM
From:http://tw.wingwit.com/Article/program/Oracle/201311/17115.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.