服务器 频道

SQL*PLUS命令的使用大全(上)

  【IT168 服务器学院】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中的批处理。

  @与@@的区别是什么?

  @等于start命令,用来运行一个sql脚本文件。

  @命令调用当前目录下的,或指定全路径,或可以通过SQLPATH环境变量搜寻到的脚本文件。该命令使用是一般要指定要执行的文件的全路径,否则从缺省路径(可用SQLPATH变量指定)下读取指定的文件。

  @@用在sql脚本文件中,用来说明用@@执行的sql脚本文件与@@所在的文件在同一目录下,而不用指定要执行sql脚本文件的全路径,也不是从SQLPATH环境变量指定的路径中寻找sql脚本文件,该命令一般用在脚本文件中。

  如:在c:\temp目录下有文件start.sql和nest_start.sql,start.sql脚本文件的内容为:

  @@nest_start.sql     - - 相当于@ c:\temp\nest_start.sql

  则我们在sql*plus中,这样执行:

  SQL> @ c:\temp\start.sql

  2. 对当前的输入进行编辑

  SQL>edit

  3. 重新运行上一次运行的sql语句

  SQL>/

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

  SQL> SPOOL file_name

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

  5. 关闭spool输出

  SQL> SPOOL OFF

  只有关闭spool输出,才会在输出文件中看到输出的内容。

  6.显示一个表的结构

  SQL> desc table_name
0
相关文章