sqlplus之 login.sql

sqlplus在启动时会自动运行两个脚本:glogin.sql、login.sql这两个文件

执行顺序为

1.默认在在$ORACLE_HOME/sqlplus/admin路径下查找glogin.sql文件执行


2.默认在在当前路径下查找login.sql文件执行,若未查找到对应文件则执行3


3.判断是否设置SQLPATH环境变量,如果设置了该变量则在对应路径下查找并执行,未找到则停止查找


login.sql

--SQLPLUS默认编辑器设置为vi
define _editor=vi
--默认打开DBMA_OUTPUT,这样不必要每次在输入这个命令,同时将默认缓冲池设置得尽可能大
set serveroutput on size 1000000
--假脱机输出文本时,会去除文本行两端的空格,而且行宽不定,如果设置为off(默认设置),假脱机输出的文本行宽度则等于所设置的linesize
set trimspool on
--设置选择LONG和CLOB列时显示的默认字节数
set long 5000
--设置显示的文本宽为200个字符
set linesize 200
--设置SQLPLUS多久打印一次标题,将此参数设置大些这样每页只显示一次标题
set pagesize 9999
--设置AUTOTRACE得到解释计划输出的默认宽度,一般80足够放下整个计划
column plan_plus_exp format a80
--设置SQLPLUS提示符,显示格式为用户@数据库名
column global_name new_value gname
set termout off
define gname=idle
column global_name new_value gname
select lower(user) ||'@'|| substr(global_name,1,decode(dot,0,length(global_name),dot-1)) global_name
from (select global_name,instr(global_name,'.') dot from global_name);
set sqlprompt '&gname>'
set termout on

使用scott用户登录后如下

C:\Users\Administrator>sqlplus /nolog

SQL*Plus: Release 11.2.0.1.0 Production on 星期四 3月 15 14:50:57 2018

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

idle>conn scott/123456
已连接。
scott@ORCL>select * from emp;

     EMPNO ENAME      JOB              MGR HIREDATE              SAL       COMM
    DEPTNO
---------- ---------- --------- ---------- -------------- ---------- ----------
----------
      7369 SMITH      CLERK           7902 17-12月-80            800
        20
      7499 ALLEN      SALESMAN        7698 20-2月 -81           1600        300
        30
      7521 WARD       SALESMAN        7698 22-2月 -81           1250        500
        30
      7566 JONES      MANAGER         7839 02-4月 -81           2975
        20
      7654 MARTIN     SALESMAN        7698 28-9月 -81           1250       1400
        30
      7698 BLAKE      MANAGER         7839 01-5月 -81           2850
        30
      7782 CLARK      MANAGER         7839 09-6月 -81           2450
        10
      7788 SCOTT      ANALYST         7566 19-4月 -87           3000
        20
      7839 KING       PRESIDENT            17-11月-81           5000
        10
      7844 TURNER     SALESMAN        7698 08-9月 -81           1500          0
        30
      7876 ADAMS      CLERK           7788 23-5月 -87           1100
        20
      7900 JAMES      CLERK           7698 03-12月-81            950
        30
      7902 FORD       ANALYST         7566 03-12月-81           3000
        20
      7934 MILLER     CLERK           7782 23-1月 -82           1300
        10

已选择14行。
idle>conn /as sysdba;
已连接。
sys@ORCL>drop role plustrace;
drop role plustrace
          *
第 1 行出现错误:
ORA-01919: 角色 'PLUSTRACE' 不存在


sys@ORCL>create role plustrace;
角色已创建。

sys@ORCL>grant plustrace to dba with admin option;
授权成功。

sys@ORCL>grant plustrace to scott;
授权成功。

sys@ORCL>grant select on v_$sesstat to plustrace;
授权成功。

sys@ORCL>grant select on v_$statname to plustrace;
授权成功。

sys@ORCL>grant select on v_$mystat to plustrace;
授权成功。

sys@ORCL>grant plustrace to dba with admin option;
授权成功。

sys@ORCL>grant plustrace to scott;
授权成功。

sys@ORCL>exit
C:\Users\Administrator>sqlplus /nolog

SQL*Plus: Release 11.2.0.1.0 Production on 星期四 3月 15 15:19:58 2018

Copyright (c) 1982, 2010, Oracle.  All rights reserved.

idle>conn scott/123456;
已连接。
scott@ORCL>set autot trace exp stat;
scott@ORCL>select * from emp;

已选择14行。


执行计划
----------------------------------------------------------
Plan hash value: 3956160932

--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |    14 |  1218 |     3   (0)| 00:00:01 |
|   1 |  TABLE ACCESS FULL| EMP  |    14 |  1218 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------

Note
-----
   - dynamic sampling used for this statement (level=2)


统计信息
----------------------------------------------------------
          0  recursive calls
          0  db block gets
          8  consistent gets
          0  physical reads
          0  redo size
       1631  bytes sent via SQL*Net to client
        520  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
         14  rows processed

scott@ORCL>
可以看到登录之后 SQLPLUS按照login.sql文件进行相应设置





你可能感兴趣的:(Oracle)