解决 XMANAGER下SQLPLUS不能使用上下左右和BACKSPACE键问题

时间:2021-11-10 17:17:14

一. 解决输入 BACKSPACE 键变成 ^h 的问题

#su - oracle 

$stty erase ^h.

要永久生效,可以加入到用户环境配置文件 .bash_profile   加入如下一行 

stty erase ^h

 

二. 解决上下左右键问题


1.  安装 readline 组件包

 ftp://ftp.gnu.org 的 gun/readline目录下,下载最新版本的 read.*.tar.gz 文件,

如:   ftp://ftp.gnu.org/gnu/readline/readline-6.1.tar.gz


然后上传到服务器进行编译安装, 相关指令:


tar zxvf 文件名

./configure   或者  perl Makefile

make

make install

2. 安装 rlwrap 组件包

到如下网页搜索下载相应操作系统版本的 rlwrap  rpm 包,这里以RHEL4为例:

http://rpm.pbone.net/index.php3/stat/4/idpl/5810350/com/rlwrap-0.30-1.el4.i386.rpm.html

如:  ftp://ftp.univie.ac.at/systems/linux/fedora/epel/4/i386/rlwrap-0.30-1.el4.i386.rpm


注意:

对于 x86_64 系统, 也安装上述 i386版的rpm包即可。

然后上传到服务器后使用类似如下指令进行安装:

#rpm -Uvh rlwrap-0.30-1.el4.i386.rpm


也可以到其官方下载源文件进行手工编译:

http://utopia.knoware.nl/~hlub/uck/rlwrap/

但是, 我在编译的时候遇到了如下错误, 所以还是推荐使用 RPM 包进行安装

=======================================================

......
readline.o(.text+0xf5c): In function `prompt_is_single_line':
/home/rlwrap-0.36/src/readline.c:686: undefined reference to `rl_variable_value'
collect2: ld returned 1 exit status
make[1]: *** [rlwrap] 错误 1
make[1]: Leaving directory `/home/rlwrap-0.36/src'
make: *** [install-recursive] 错误 1
......

=======================================================

3. 使用方法
可以手动输入如下指令使用:
# rlwrap sqlplus "/as sysdba"


为了方便,也可以在Oracle用户环境配置文件
.bash_profile 中加入如下语句:

stty erase ^h   

alias sqlplus='rlwrap sqlplus'


最后,再次进入sqlplus,上下左右和Backspace键都可以用了