西西软件园多重安全检测下载网站、值得信赖的软件下载站!
软件
软件
文章
搜索

首页西西教程数据库教程 → sql plus 与Oracle交互常用令与sql plus语句

sql plus 与Oracle交互常用令与sql plus语句

相关软件相关文章发表评论 来源:本站整理时间:2010/8/20 11:04:11字体大小:A-A+

作者:佚名点击:1358次评论:0次标签: sql Oracle

  • 类型:电子教程大小:8.5M语言:中文 评分:8.3
  • 标签:
立即下载
4 页 编辑sql buffer中的sql语句
15.编辑sql buffer中的sql语句
EDI[T]
 
16.显示sql buffer中的sql语句,list n显示sql buffer中的第n行,并使第n行成为当前行
L[IST] [n]
 
17.在sql buffer的当前行下面加一行或多行
I[NPUT]
 
18.将指定的文本加到sql buffer的当前行后面
A[PPEND]
SQL> select deptno,
   2  dname
   3  from dept;
     DEPTNO DNAME
---------- --------------
         10 ACCOUNTING
         20 RESEARCH
         30 SALES
         40 OPERATIONS
 
SQL> L 2
   2* dname
SQL> a ,loc
   2* dname,loc
SQL> L
   1  select deptno,
   2  dname,loc
   3* from dept
SQL> /
 
     DEPTNO DNAME          LOC
---------- -------------- -------------
         10 ACCOUNTING     NEW YORK
         20 RESEARCH       DALLAS
         30 SALES          CHICAGO
         40 OPERATIONS     BOSTON
 
19.将sql buffer中的sql语句保存到一个文件中
SAVE file_name
 
20.将一个文件中的sql语句导入到sql buffer中
GET file_name
 
21.再次执行刚才已经执行的sql语句
RUN
or
/
 
22.执行一个存储过程
EXECUTE procedure_name
 
23.在sql*plus中连接到指定的数据库
CONNECT user_name/passwd@db_alias
 
24.设置每个报表的顶部标题
TTITLE
 
25.设置每个报表的尾部标题
BTITLE
 
26.写一个注释
REMARK [text]
 
27.将指定的信息或一个空行输出到屏幕上
PROMPT [text]
 
28.将执行的过程暂停,等待用户响应后继续执行
PAUSE [text]
 
Sql>PAUSE Adjust paper and press RETURN to continue.
 
29.将一个数据库中的一些数据拷贝到另外一个数据库(如将一个表的数据拷贝到另一个数据库)
COPY {FROM database | TO database | FROM database TO database}
{APPEND|CREATE|INSERT|REPLACE} destination_table
[(column, column, column, ...)] USING query
 
sql>COPY FROM SCOTT/TIGER@HQ TO JOHN/CHROME@WEST  
create emp_temp
USING SELECT * FROM EMP
 
30.不退出sql*plus,在sql*plus中执行一个操作系统命令:
HOST
 
Sql> host hostname
该命令在windows下可能被支持。
 
31.在sql*plus中,切换到操作系统命令提示符下,运行操作系统命令后,可以再次切换回sql*plus:
!
 
sql>!
$hostname
$exit
sql>
 
该命令在windows下不被支持。
 
32.显示sql*plus命令的帮助
HELP
如何安装帮助文件:
Sql>@ ?\sqlplus\admin\help\hlpbld.sql ?\sqlplus\admin\help\helpus.sql
Sql>help index
 
33.显示sql*plus系统变量的值或sql*plus环境变量的值
Syntax
SHO[W] option
where option represents one of the following terms or clauses:
system_variable
ALL
BTI[TLE]
ERR[ORS] [{FUNCTION|PROCEDURE|PACKAGE|PACKAGE BODY|
TRIGGER|VIEW|TYPE|TYPE BODY} [schema.]name]
LNO
PARAMETERS [parameter_name]
PNO
REL[EASE]
REPF[OOTER]
REPH[EADER]
SGA
SPOO[L]
SQLCODE
TTI[TLE]
USER
 
1) . 显示当前环境变量的值:
Show all
 
2) . 显示当前在创建函数、存储过程、触发器、包等对象的错误信息
Show error
当创建一个函数、存储过程等出错时,变可以用该命令查看在那个地方出错及相应的出错信息,进行修改后再次进行编译。
 
3) . 显示初始化参数的值:
show PARAMETERS [parameter_name]
 
4) . 显示数据库的版本:
show REL[EASE]
 
5) . 显示SGA的大小
show SGA
 
6). 显示当前的用户名
show user 
from

34.查询一个用户下的对象   
SQL>select * from tab;   
SQL>select * from user_objects;   

35.查询一个用户下的所有的表   
SQL>select * from user_tables;   

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   

    相关评论

    阅读本文后您有什么感想? 已有人给出评价!

    • 8 喜欢喜欢
    • 3 顶
    • 1 难过难过
    • 5 囧
    • 3 围观围观
    • 2 无聊无聊

    热门评论

    最新评论

    发表评论 查看所有评论(0)

    昵称:
    表情: 高兴 可 汗 我不要 害羞 好 下下下 送花 屎 亲亲
    字数: 0/500 (您的评论需要经过审核才能显示)