服务器 频道

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

  【IT168 服务器学院】36.查询一个用户下的所有的索引

  SQL>select * from user_indexes;

  37. 定义一个用户变量

  方法有两个:

  a. define

  b. COL[UMN] [{column|expr} NEW_V[ALUE] variable [NOPRI[NT]|PRI[NT]]

   OLD_V[ALUE] variable  [NOPRI[NT]|PRI[NT]]

  下面对每种方式给予解释:

  a. Syntax

  DEF[INE] [variable]|[variable = text]

  定义一个用户变量并且可以分配给它一个CHAR值。

  assign the value MANAGER to the variable POS, type:

  SQL> DEFINE POS = MANAGER

  assign the CHAR value 20 to the variable DEPTNO, type:

  SQL> DEFINE DEPTNO = 20

  list the definition of DEPTNO, enter

  SQL> DEFINE DEPTNO

  ―――――――――――――――

  DEFINE DEPTNO = ”20” (CHAR)

  定义了用户变量POS后,就可以在sql*plus中用&POS或&&POS来引用该变量的值,sql*plus不会再提示你给变量输入值。

  b. COL[UMN] [{column|expr} NEW_V[ALUE] variable [NOPRI[NT]|PRI[NT]]

  NEW_V[ALUE] variable

  指定一个变量容纳查询出的列值。

  例:column col_name new_value var_name noprint

  select col_name from table_name where ……..

  将下面查询出的col_name列的值赋给var_name变量.

  一个综合的例子:

  得到一个列值的两次查询之差(此例为10秒之内共提交了多少事务):

  column redo_writes new_value commit_count

  select sum(stat.value) redo_writes

  from v$sesstat stat, v$statname sn

  where stat.statistic# = sn.statistic#

  and sn.name = ''user commits'';

  -- 等待一会儿(此处为10秒);

  execute dbms_lock.sleep(10);

  set veri off

  select sum(stat.value) - &commit_count commits_added

  from v$sesstat stat, v$statname sn

  where stat.statistic# = sn.statistic#

  and sn.name = ''user commits'';

  38. 定义一个绑定变量

  VAR[IABLE] [variable [NUMBER|CHAR|CHAR (n)|NCHAR|NCHAR (n) |VARCHAR2 (n)|NVARCHAR2 (n)|CLOB|NCLOB|REFCURSOR]]

  定义一个绑定变量,该变量可以在pl/sql中引用。

  可以用print命令显示该绑定变量的信息。

  如:

  column inst_num  heading "Inst Num"  new_value inst_num  format 99999;

  column inst_name heading "Instance"  new_value inst_name format a12;

  column db_name   heading "DB Name"   new_value db_name   format a12;

  column dbid      heading "DB Id"     new_value dbid      format 9999999999 just c;

  prompt

  prompt Current Instance

  prompt ~~~~~~~~~~~~~~~~

  select d.dbid            dbid

  , d.name            db_name

  , i.instance_number inst_num

  , i.instance_name   inst_name

   from v$database d,

   v$instance i;

  variable dbid       number;

  variable inst_num   number;

  begin

   :dbid      :=  &dbid;

   :inst_num  :=  &inst_num;

  end;

  /

  说明:

  在sql*plus中,该绑定变量可以作为一个存储过程的参数,也可以在匿名PL/SQL块中直接引用。为了显示用VARIABLE命令创建的绑定变量的值,可以用print命令

  注意:

  绑定变量不同于变量:

  1.        定义方法不同

  2.        引用方法不同

  绑定变量::variable_name

  变量:&variable_name or &&variable_name

  3.在sql*plus中,可以定义同名的绑定变量与用户变量,但是引用的方法不同。

  39. &与&&的区别

  &用来创建一个临时变量,每当遇到这个临时变量时,都会提示你输入一个值。

  &&用来创建一个持久变量,就像用用define命令或带new_vlaue字句的column命令创建的持久变量一样。当用&&命令引用这个变量时,不会每次遇到该变量就提示用户键入值,而只是在第一次遇到时提示一次。

  如,将下面三行语句存为一个脚本文件,运行该脚本文件,会提示三次,让输入deptnoval的值:

  select count(*) from emp where deptno = &deptnoval;

  select count(*) from emp where deptno = &deptnoval;

  select count(*) from emp where deptno = &deptnoval;

  将下面三行语句存为一个脚本文件,运行该脚本文件,则只会提示一次,让输入deptnoval的值:

  select count(*) from emp where deptno = &&deptnoval;

  select count(*) from emp where deptno = &&deptnoval;

  select count(*) from emp where deptno = &&deptnoval;

  40.在输入sql语句的过程中临时先运行一个sql*plus命令

  #

  有没有过这样的经历? 在sql*plus中敲了很长的命令后, 突然发现想不起某个列的名字了, 如果取消当前的命令,待查询后再重敲, 那太痛苦了. 当然你可以另开一个sql*plus窗口进行查询, 但这里提供的方法更简单.

  比如说, 你想查工资大于4000的员工的信息, 输入了下面的语句:

  SQL> select deptno, empno, ename

  2 from emp

  3 where

  这时, 你发现你想不起来工资的列名是什么了.

  这种情况下, 只要在下一行以#开头, 就可以执行一条sql*plus命令, 执行完后, 刚才的语句可以继续输入

  SQL>> select deptno, empno, ename

  2 from emp

  3 where

  6 #desc emp

  Name Null? Type

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

  EMPNO NOT NULL NUMBER(4)

  ENAME VARCHAR2(10)

  JOB VARCHAR2(9)

  MGR NUMBER(4)

  HIREDATE DATE

  SAL NUMBER(7,2)

  COMM NUMBER(7,2)

  DEPTNO NUMBER(2)

  6 sal > 4000;

  DEPTNO EMPNO ENAME

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

  10 7839 KING

  41. SQLPlus中的快速复制和粘贴技巧

  1) 鼠标移至想要复制内容的开始

  2) 用右手食指按下鼠标左键

  3) 向想要复制内容的另一角拖动鼠标,与Word中选取内容的方法一样

  4) 内容选取完毕后(所选内容全部反显),鼠标左键按住不动,用右手中指按鼠标右键

  5) 这时,所选内容会自动复制到SQL*Plus环境的最后一行

0
相关文章