可以将login.sql文件拷贝到oracle用户的当前目录下(home/oracle)或者设置SQLPATH环境变量,指向login.sql所在的目录。
注:放在当前目录,直接sqlplus / as sysdba 即会使用login.sql,
如果是设置SQLPATH,可以export SQLPATH='login.sql所放目录'
在我的实验中出现个问题,如果数据库没有启动,则这样启动的话,显示是有问题的。
以后我们在使用别到别的参数时,可以自己手动在login.sql文件中添加。
define _editor=vi
set serveroutput on size 1000000
set trimspool on
set long 5000
set linesize 100
set pagesize 9999
column plan_plus_exp format a80
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
附:login.sql文件中部分参数说明:
1. define _editor=vi: 设置SQL *Plus使用的默认编辑器。
2. set serveroutput on size 1000000:这样会默认的打开DBMS_OUTPUT(这样不必每次在键入这个命令了)。另外也将默认缓冲区大小设置的仅可能大。
3. set trimspool on: 假脱机输出文本时,会去除文本行两端的空格,而且行宽不定,如果设置为off(默认设置),假脱机输出的文本行宽度则等于所设置的linesize。
4. set long 5000: 设置选择LONG和CLOB列时显示的默认字节数。
5. set linesize 100 设置SQL*Plus显示的文本宽为100个字符
6. set pagesize 9999: pagesize可以控制SQL *Plus多久打印一次标题。
7. column plan_plus_exp format a80: 设置由AUTOTRACE得到的解释计划输出的默认宽度。
8.set termout off 不显示输出结果
9.
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 |
column global_name new_value gname 指令告诉SQL *Plus取得global_name列中的最后一个值,并将这个值赋给替换变量gname,接下来从数据库中选出global_name,并与我的登录用户名连接。得到的SQL *Plus提示符为:user_analysis@ORA9I>这样就可以知道当前用户是谁,以及连接的数据库SID