SQL Plus常用命令

来源:互联网 发布:卖家如何加入淘宝客 编辑:程序博客网 时间:2024/06/11 07:39

SQL*PlusOracle数据库交互的客户端工具,在SQL*Plus中可以运行SQL*Plus命令和SQL*Plus语句。

我们通常说的DMLDDLDCL都是SQL*Plus语句,它们执行完成后,都保存在一个被称为SQL buffer的内存区域,并且只能保存最后一条执行的SQL语句,我们可以对保存在SQL buffer中的SQL语句进行修改,然后再次执行。

除了SQL*Plus语句,在SQL*Plus中执行的其它语句我们称之为SQL*Plus命令,它们执行完成后,不保存在SQL buffer中,这些命令一般是用来对输出结果进行格式化显示。

 

1.       执行一个SQL脚本文件

SQL> start file_nameSQL> @file_name 

可以将多条SQL语句保存在一个文本文件中,执行这个文件就可以执行文件中的所有命令,这类似于dos中的批处理。

 

2.       编辑SQL buffer的内容

SQL> edit 

3.       重新运行上次运行的SQL语句

SQL> / 

4.       将显示内容输出到指定文件中

SQL> spool file_name

 

在屏幕上的所有内容都包含在该文件中,包括你输入的sql语句。

输出完成必须使用下列命令关闭spool输出

 

SQL> spool off

 

5.       显示一个表的结构

SQL> desc table_nameDESC可以用来显示表、视图的列的定义,也可以显示同义词、函数或存储过程的说明此命令非常有用,以后会经常用到 

6.       在用start命令执行一个sql脚本时,是否显示脚本中正在执行的SQL语句

SQL> SET ECHO {ON|OFF} 

7.       是否显示当前sql语句查询或修改的行数

         SQL> SET FEED[BACK] {6|n|ON|OFF}默认只有结果大于6行时才显示结果的行数。如果set feedback 1 ,则不管查询到多少行都返回。当为off 时,一律不显示查询的行数 

8.       是否显示列标题

SQL> SET HEA[DING] {ON|OFF}

set heading off 时,在每页的上面不显示列标题,而是以空白行代替

 

9.       设置一行可以容纳的字符数

SQL> SET LIN[ESIZE] {80|n}

如果一行的输出内容大于设置的一行可容纳的字符数,则折行显示。 

10.   设置页与页之间的分隔

SQL> SET NEWP[AGE] {1|n|NONE} set newpage 0 时,会在每页的开头有一个小的黑方框。
set newpage n 时,会在页和页之间隔着n个空行。
set newpage none 时,会在页和页之间没有任何间隔。 

11.   设置一页有多少行数

SQL> SET PAGES[IZE] {24|n} 如果设为0,则所有的输出内容为一页并且不显示列标题  

12.   是否显示用DBMS_OUTPUT.PUT_LINE包进行输出的信息

SQL> SET SERVEROUT[PUT] {ON|OFF} 在编写存储过程时,我们有时会用dbms_output.put_line将必要的信息输出,以便对存储过程进行调试,只有将serveroutput变量设为on后,信息才能显示在屏幕上。  

13.   SQL语句的长度大于LINESIZE时,是否在显示时截取SQL语句

SQL> SET WRA[P] {ON|OFF} 

当输出的行的长度大于设置的行的长度时(用set linesize n命令设置),当set wrap on时,输出行的多于的字符会另起一行显示,否则,会将输出行的多于字符切除,不予显示。

 

14.   是否在屏幕上显示输出的内容,主要用与SPOOL结合使用

SQL> SET TERM[OUT] {ON|OFF}

 在用spool命令将一个大表中的内容输出到一个文件中时,将内容输出在屏幕上会耗费大量的时间,设置set termspool off后,则输出的内容只会保存在输出文件中,不会显示在屏幕上,极大的提高了spool的速度。 

15.   SPOOL输出中每行后面多余的空格去掉

SQL> SET TRIMS[OUT] {ON|OFF} 

16.   显示每个sql语句花费的执行时间

SQL> set TIMING {ON|OFF} 

17.   执行一个存储过程

SQL> EXECUTE procedure_name  

18.   将指定的信息或一个空行输出到屏幕上

SQL> PROMPT [text]

 

19.   显示数据库的版本

SQL> show relOracle Database 10g Enterprise Edition Release 10.2.0.1.0  

20.   显示当前的用户名

SQL> show userUser is “S001″ 

21.   显示当前在创建函数、存储过程、触发器、包等对象的错误信息

SQL> show error 

22.   显示当前环境变量的值

SQL> show all  

原创粉丝点击