数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

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


发布日期:2022年07月11日
 
Oracle的SQL*PLUS命令的使用大全

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 DNAMELOC

ACCOUNTING NEW YORK

sql>colLOC heading location

sql>select * from dept;

DEPTNO DNAMElocation

ACCOUNTING NEW YORK

) 将列名ENAME改为新列名EMPLOYEE NAME并将新列名放在两行上

Sql>select * from emp

Departmentname Salary

aaa

SQL> COLUMN ENAME HEADING Employee|Name

Sql>select * from emp

Employee

Departmentname Salary

aaa

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

) 改变列的显示长度

FOR[MAT] format

Sql>select empnoenamejob from emp;

EMPNO ENAMEJOB

SMITHCLERK

ALLENSALESMAN

WARD SALESMAN

Sql> col ename format a

EMPNO ENAMEJOB

SMITHCLERK

ALLENSALESMAN

WARDSALESMAN

) 设置列标题的对齐方式

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

SQL> col ename justify center

SQL> /

EMPNO ENAME JOB

SMITHCLERK

ALLENSALESMAN

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 NameSalaryCommission

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;

DEPTNOENAME 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               

上一篇:如何选择Oracle优化器

下一篇:Oracle客户端与数据库应用程序集成安装