一 安装oracle数据库成功之后,会显示相关的数据库信息:
全局数据库名:oracle
系统标识符(SID):oracle
服务器参数文件名:c:\oracle\product\10.2.0\db_1/dbs/spfileoracle.ora
Database Control URL为http://210.45.216.146:1158/em
数据库账户:SYS,SYSTEM,DBSNMP,SYSMAN
密码:oracle
isql*Plus URL 为:
http://210.45.216.146:5561/isqlplus
isql*Plus DBA URL 为:
http://210.45.216.146:5561/isqlplus/dba
查看C:\oracle\product\10.2.0\db_1\install\portlist.ini文件获得相应的OEM为:
http://210.45.216.146:1158/em/
二 sqlPLUS工具
sqlPLUS的主要功能为:输入,运行和调试sql语句和PL/sql块;执行管理数据库命令;处理数据,生成报表,格式化查询结果
1.启动sqlPLUS:
scott/tiger@oracle
2.获取sqlPLUS命令的帮助:
sql> help index; //获得oracle所有命令
sql> help list; //显示出list命令的帮助信息
3.退出sqlPLUS(在退出sqlPLUS之前,应该使用commit命令提交事务):
sql> quit或者sql> exit;
4.在sqlPLUS中输入三种类型的命令:
1) sql命令:用于操作数据库中的信息
2) PL/sql块:用于操作数据库中的信息
3) sqlPLUS命令:用于编辑,保存,运行sql命令,PL/sql块,格式化查询结果,自定义sqlPLUS环境等.
1),2)可以访问数据库,执行时将命令暂时存放到sql缓冲区中.
3)不可以访问数据库,sqlPLUS命令也不能被存放到sql缓冲区中. 5.缓冲区命令:
sql>SELECT ; //把SELECT;保存到缓冲区中
sql>EDIT; //编辑缓冲区中的内容
sql>RUN 或者sql>/ //执行缓冲区中的内容
sql>CLEAR SCREEN //清除sqlPLUS的屏幕及屏幕缓冲区
6.运行命令
在sqlPLUS中可以使用三种方式运行sql语句和PL/sql块:1)命令行方式 2)sql缓冲区方式 3)脚本文件方式
1)命令行方式:
1.1)以命令行方式运行sql命令,只需要在输入完sql语句之后,输入分号(;),或者在新的一行输入前斜线(/),按回车键即可
sql> SELECT ename,sal FROM emp
2 WHERE deptno = 20;
1.2)以命令行方式运行PL/sql块,只需要在输入完PL/sql块之后,在新的一行输入前斜线(/),按回车键即可
sql> SET SERVEROUTPUT ON
sql> BEGIN
2 DBMS_OUTPUT.PUT_LINE('Hello Oracle!');
3 END;
4 /
1.3)EXECUTE(或者EXEC)命令,可以执行单条PL/sql语句,不需要从缓冲区或脚本文件中执行.
sql> SET SERVEROUTPUT ON
sql> EXEC DBMS_OUTPUT.PUT_LINE('Hello ');
Hello
2)sql缓冲区方式:
2.1)RUN命令:显示并运行当前存储在sql缓冲区中的sql语句或PL/sql块,显示运行结果,
并使sql缓冲区中的最后一行成为当前行
sql> SELECT ename,sal FROM emp
2 WHERE deptno = 20
3 ;
ENAME SAL
---------- ----------
SMITH 800
JONES 2975
SCOTT 3000
ADAMS 1100
FORD 3000
sql> RUN
1 SELECT ename,sal FROM emp
2 WHERE deptno = 20
3*
ENAME SAL
---------- ----------
SMITH 800
JONES 2975
SCOTT 3000
ADAMS 1100
FORD 3000
2.2)/命令:运行当前存储在sql缓冲区中的sql命令或PL/sql块,
而不显示sql缓冲区中的sql命令或PL/sql块,也不会将sql缓冲区中的最后一行成为当前行
sql> SET SERVEROUTPUT ON
sql> BEGIN
2 DBMS_OUTPUT.PUT_LINE('HELLO,ORACLE!');
3 END;
4 /
HELLO,ORACLE!
PL/sql 过程已成功完成。
sql> /
HELLO,ORACLE!
PL/sql 过程已成功完成。
2.3)菜单命令
选择"文件"->"运行",它与RUN命令相同
3)脚本文件方式
3.1)START命令
格式: START filename[.ext] [arg1 arg2 arg3...]
脚本文件:D:\test.sql内容如下:
SELECT ename,sal FROM emp
WHERE deptno = &1
AND sal > &2;
使用START命令:
sql> START D:\test.sql 20 2500
原值 2: WHERE deptno = &1
新值 2: WHERE deptno = 20
原值 3: AND sal > &2
新值 3: AND sal > 2500
ENAME SAL
---------- ----------
JONES 2975
SCOTT 3000
FORD 3000
3.2)@命令
@命令和START命令类似,区别在于:@命令既可以在sqlPLUS会话内部运行,也可以在命令行运行,
而START命令只能在sqlPLUS会话内运行.
7.替换变量命令
1)使用替换变量:其格式是在变量名称之前加一个&,以便在运行sql命令时提示用户输入替换数据,
然后按输入数据运行sql命令,如:
sql> SELECT &a FROM emp
2 WHERE deptno = 20
3 AND job = '&b';
输入 a 的值: ename
原值 1: SELECT &a FROM emp
新值 1: SELECT ename FROM emp
输入 b 的值: CLERK
原值 3: AND job = '&b'
新值 3: AND job = 'CLERK'
ENAME
----------
SMITH
ADAMS
2)定义替换变量:事先用DEFINE命令定义替换变量,如:
sql> DEFINE a = CLERK
sql> SELECT ename FROM emp
2 WHERE deptno = 20
3 AND job = '&a';
原值 3: AND job = '&a'
新值 3: AND job = 'CLERK'
ENAME
----------
SMITH
ADAMS
3)查看替换变量
sql> DEFINE a
DEFINE A = "CLERK" (CHAR)
4)清除替换变量
sql> UNDEFINE a
8.与用户通信
可以使用PROMPT命令,PAUSE命令,ACCEPT命令与用户进行通信
1)PROMPT命令用于输出提示信息,以便使用户了解脚本文件的功能和运行情况
2)PAUSE命令用于暂停脚本文件的运行
3)ACCEPT命令可以让用户指定替换变量的类型(如CHAR,NUMBER,DATE),用PROMPT选项指定提示信息,
用HIDE选项隐藏输入,以便于用户输入替换变量
举例如下:
脚本文件:D:\test.sql内容如下:
ACCEPT pwd PROMPT '请输入密码' HIDE
PROMPT
PROMPT 显示XX部门XX工种的员工姓名
PROMPT ==========================
PROMPT 按
PAUSE
ACCEPT a NUMBER PROMPT '请输入部门:'
ACCEPT b CHAR PROMPT '请输入工种:'
SELECT ename FROM emp
WHERE deptno = &a
AND job = '&b';
该脚本文件运行结果为:
sql> START D:\test.sql
请输入密码*********
显示XX部门XX工种的员工姓名
==========================
按
请输入部门:20
请输入工种:CLERK
原值 2: WHERE deptno = &a
新值 2: WHERE deptno = 20
原值 3: AND job = '&b'
新值 3: AND job = 'CLERK'
ENAME
----------
SMITH
ADAMS
9.绑定变量
1)定义绑定变量
可以使用VARIABLE命令来定义绑定变量.当在sql语句或PL/sql块中使用绑定变量时,
必须在绑定变量前加冒号(:).当直接给绑定变量赋值时,需要使用EXECUTE命令,例如:
sql> VARIABLE no NUMBER
sql> EXECUTE :no := 7788
PL/sql 过程已成功完成。
sql> SELECT ename FROM emp WHERE empno = :no;
ENAME
----------
SCOTT
2)输出绑定变量
使用PRINT命令输出绑定变量,例如:
sql> PRINT no
NO
----------
7788
10.自定义sqlPLUS环境
sql> SHOW ALL //查看所有环境变量
sql> SHOW linesize pagesize
sql> SET linesize 100 pagesize 24 //linesize代表行宽度,默认为80,pagesize表示每页显示的行数,默认为24
sql> SHOW arraysize //arraysize用于设置从数据库中一次提取的行数,默认为15
sql> SET arraysize 25
sql> SHOW autocommit //autocommit用于设置是否自动提交,默认为OFF
sql> SET autocommit on
sql> SET colsep | //colsep 用于设置在选定列之间的分隔符,默认为空格
sql> SELECT ename,sal FROM emp WHERE empno = 7788;
ENAME | SAL
----------|----------
SCOTT | 3000
sql>SET heading off //heading表示是否显示列标题,默认为ON
sql> SELECT ename,sal FROM emp WHERE empno = 7788;
SCOTT | 3000
sql> SET serveroutput on //SEVEROUTPUT用于控制是否显示存储过程的输出,默认为OFF
sql> EXEC dbms_output.put_line('hello oracle');
hello oracle
PL/sql 过程已成功完成。
sql> SET sqlprompt inputsql> //sqlprompt用来设置sqlPLUS的命令提示符
inputsql>
sql>SET time on //time是否在sqlPLUS命令提示符前显示系统时间,默认设置为OFF
19:02:35 sql> sql>SET underline = //underline用于设置下划线字符,默认值为"_"
sql>SELECT count(*) FROM emp;
COUNT(*)
==========
14
sql>STORE SET D:\setfile.sql //保存当前的sqlPLUS环境
已创建 file D:\setfile.sql
11.格式化查询结果
1)格式化列
sql> COLUMN ename HEADING 雇员 JUSTIFY CENTER FORMAT A4
sql> COLUMN sal HEADING 月薪 JUSTIFY CENTER FORMAT L99999.99
sql> SELECT ename,sal FROM emp WHERE deptno = 20 AND sal > 2500;
雇员| 月薪
====|===================
JONE| ¥2975.00 SCOT| ¥3000.00
T |
FORD| ¥3000.00
sql>COLUMN sal CLEAR //恢复列的格式
2)限制重复行
在限制重复行的同时,还可以在各个分组之间插入n个空行,其语法为:
BREAK ON break_column SKIP n
跑到新的一页,其语法为:
BREAK ON break_column SKIP PAGE
在每行之后插入n个空行,其语法为:
BREAK ON ROW SKIP n
在报表之后插入n个空行,其语法为:
BREAK ON REPORT SKIP n
sql> BREAK ON deptno SKIP 1
sql> SELECT deptno,ename,sal FROM emp WHERE sal < 2500
2 ORDER BY deptno;
DEPTNO ENAME SAL
---------- ---------- ----------
10 CLARK 2450
MILLER 1300
20 ADAMS 1100
SMITH 800
30 WARD 1250
MARTIN 1250
JAMES 950
TURNER 1500
ALLEN 1600
已选择9行。