实用技巧:让SQLPlus变得好用的几个配置

文章介绍了如何通过安装READLINE和RLWRAP来改善SQLPlus的使用体验,使其支持Backspace删除和历史SQL浏览。同时,展示了如何配置SQLPlus的提示符,显示更多连接信息,提供更友好的交互环境。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实用技巧:让SQLPlus变得好用的几个配置

READLINE + RLWRAP

初次使用SQLPlus的人通常都会觉得这个客户端工具很难用,通过配置readline + rlwrap可以使我们像使用MySQL客户端一样地使用SQLPlus以及RMAN。不仅支持Backspace删除,同时还支持上下方向键查看执行过的历史SQL。

安装RLWRAP

安装readline工具:

[root@localhost ~]# yum install -y readline*
[root@localhost ~]# yum install -y gcc-c++

安装rlwrap工具:

[root@localhost ~]# tar -xvf rlwrap-0.45.2.tar.gz
[root@localhost ~]# cd rlwrap-0.45.2/
[root@localhost ~]# ./configure && make && make install

🐬rlwrap下载:https://github.com/hanslub42/rlwrap/releases/tag/v0.45.2

使用RLWRAP

为Oracle配置rlwrap工具:

[oracle@localhost ~]$ cat .bash_profile
# .bash_profile

# Get the aliases and functions
if [ -f ~/.bashrc ]; then
        . ~/.bashrc
fi

# User specific environment and startup programs

PATH=$PATH:$HOME/.local/bin:$HOME/bin
export PATH

# 配置Oracle环境变量
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/version/db_1
export ORACLE_SID=orclcdb
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export PATH=$PATH:$ORACLE_HOME/bin:$JAVA_HOME/bin
export PATH=$JAVA_HOME/bin:$ORACLE_HOME/bin:$PATH

# 为Oracle命令配置配置别名
alias sysdba='rlwrap sqlplus / as sysdba'
alias rman='rlwrap rman'
alias lsnrctl='rlwrap lsnrctl'
alias asmcmd='rlwrap asmcmd'
alias adrci='rlwrap adrci'

unset TWO_TASK

使配置生效:

[oracle@localhost ~]$ . .bash_profile
#或者 source .bash_profile

SQLPlus提示符配置

默认登录后,SQLPlus的提示符是下面的样子,没有任何有用信息:

SQL>

修改配置文件$ORACLE_HOME/sqlplus/admin/glogin.sql,在末尾添加以下内容:

define_editor=vi
set timing on
set serveroutput on size 100000
set linesize 100
set trimspool on
set long 5000
set termout off
default gname=idle
column global_name new_value gname
SELECT lower(USER) || '@' ||upper(instance_name)||'('||nvl(UTL_INADDR.GET_HOST_ADDRESS, SYS_CONTEXT('userenv', 'ip_address'))||')' GLOBAL_NAME FROM v$instance;
set sqlprompt '&gname> '
set termout on

再次登录SQLPlus试试看:

[oracle@localhost ~]$ sysdba

SQL*Plus: Release 19.0.0.0.0 - Production on Thu May 18 08:09:06 2023
Version 19.3.0.0.0

Connected to:
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0

sys@ORCLCDB(127.0.0.1)>
sys@ORCLCDB(127.0.0.1)>

SQLPlus的提示符中显示了当前连接的用户、实例名称、以及服务器IP信息。

😄是不是很棒呀~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GottdesKrieges

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值