一、rlwarp安装


下载:http://rpmfind.net/linux/rpm2html/search.php?query=rlwrap


下载对应的版本,如:rlwrap-0.42-1.el7.x86_64.rpm


rpm -ivh rlwrap-0.42-1.el7.x86_64.rpm


alias sqlplus='rlwrap sqlplus'


二、设置sqlplus 环境变量



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


执行顺序为


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


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


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


可以在login.sql文件中加入一些常用设置使用SQLPLUS时更便捷,以下试验在ORACLE 11.2.0.1.0上进行


默认$ORACLE_HOME/sqlplus/admin路径下存在glogin.sql文件


当前用户的profile文件中设置SQLPATH环境变量 export SQLPATH=$ORACLE_HOME/sqlplus/admin:$SQLPATH


在默认路径下加入我们自己的login.sql文件,以下配置为常用配置



vim $ORACLE_HOME/sqlplus/admin/glogin.sql


--SQLPLUS默认编辑器设置为vi
define _editor=vim
--默认打开DBMA_OUTPUT,这样不必要每次在输入这个命令,同时将默认缓冲池设置得尽可能大
set serveroutput on size 1000000
--假脱机输出文本时,会去除文本行两端的空格,而且行宽不定,如果设置为off(默认设置),假脱机输出的文本行宽度则等于所设置的linesize
set trimspool on
--设置选择LONG和CLOB列时显示的默认字节数
set long 5000
--设置显示的文本宽为200个字符
set linesize 200
--
set wrap on 
-- 设置number类型字段长度为16
set numwidth 16 
--设置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