解决Linux下SQL*Plus命令行历史回调功能

来源:赛迪网 作者:茶晶
  利用Uniread解决Linux下SQL*Plus命令行历史回调功能:

 

该工具叫做 uniread - http://sourceforge.net/projects/uniread/ ) ,熟悉Linux下变成的朋友可能看到这个名字已经想起了一些东西:readline . 不错,该工具就是利用GNU的readline库来完成我们的需求的.

 

我们先看一下对该工具的介绍:

uniread - universal readline

- adds full readline support (command editing, history, etc.) to any existing interactive command-line program. Common examples are Oracle's sqlplus or jython. uniread will work on any POSIX platform with Perl.

可以看出,该工具可以对任何既有的交互命令行程序都可提供完备的readline支持.

 

从该站点下载源程序.目前的稳定版本是1.01.

 

在安装该工具之前系统必须安装好Perl, 此外还必须要三个工具包:

 

GNU readline

http://cnswww.cns.cwru.edu/php/chet/readline/rltop.html

Term::ReadLine::Gnu

http://search.cpan.org/dist/Term-ReadLine-Gnu/

IO::Tty

http://search.cpan.org/dist/IO-Tty/

其中GNU readline 上面的网页在我的机器上打不开(不可访问?),如果你也是同样情况,可以到 http://www.gnu.org/directory/readline.html 这个页面下载.

 

下载后,首先解压缩:

 

# tar -xzvf readline-4.3.tar.gz

进入进入到该目录中编译并安装:

# ./configure

# make

# make install

后面两个的安装: tar -zxvf ...... 进入到该目录中: (最好先装IO-Tty-1.07.tar.gz,我是这样装的)

# perl Makefile.pl

# make

# make install

都安装完了之后,进行 uniread 的安装:

#tar -xzvf uniread-1.01.tar.gz

#cd uniread-1.01

#./configure

#make

#make install

注: 以上的命令行操作所在绝对路径为了方便而省略,你的环境肯定会和我的不同,此外,建议使用普通用户编译,然后用 root 进行 make install .

 

都安装完了之后切换到Oracle用户下:

 

$ uniread sqlplus /nolog

输出类似如下:

 

[uniread] Loaded history (12 lines) //我的已经运行一次了,uniread 缓冲了12行history

 

SQL*Plus: Release 10.1.0.2.0 - Production on Sat Mar 6 00:23:05 2004

 

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

 

SQL>

查看uniread的Manual:

 

$man uniread

你可以做个sqlplus 的别名 ,uniread的使用是透明的,是不是很方便了? 不要忘了:这个工具是有通用性的,不止是 SQL*Plus 可以这样用,其他类似的命令行程序也能如此的.

 

FAQ

如果要删除命令行历史,可以简单的用如下操作即可:

 

[oracle@FOO oracle]$ echo ''>.uniread/sqlplus

[oracle@FOO oracle]$

[oracle@FOO oracle]$ ls -ltr .uniread/

total 4

-rw------- 1 oracle oracle 1 Oct 31 15:57 sqlplus

[oracle@FOO oracle]$

[oracle@FOO oracle]$ uniread sqlplus

[uniread] Loaded history (1 lines)

 

SQL*Plus: Release 9.2.0.4.0 - Production on Sun Oct 31 15:58:29 2004

 

......

(责任编辑:A6)


时间:2008-07-29 08:57 来源:赛迪网 作者:茶晶 原文链接

好文,顶一下
(0)
0%
文章真差,踩一下
(0)
0%
------分隔线----------------------------


把开源带在你的身边-精美linux小纪念品
无觅相关文章插件,快速提升流量