解决Linux/Unix下OCI程序动态库版本的问题

这段时间做了好几个基础OCI的程序,在Windows上编译后,不需要重新编译, 就可以适应8i/9i/10g的客户端,但在Linux/Unix上,编译好后到不同的版本的客户端去运行时, 总会提示找不到动态库libclntsh.., 这时可以用以下办法去解决:

    第一步,修改genclntsh文件,这个文件在Oracle的bin目录下

#
# Library names and locations
CLNT_NAM=clntsh                      # (short) library name
CLNT_VER=9.0                        # library version number
CLNT_LNK=lib${CLNT_NAM}.so          # name of symlink to library
CLNT_LIB=${CLNT_LNK}.${CLNT_VER}    # actual library file name
LIB_DIR=${ORACLE_HOME}/${LIB}        # lib. destination directory

    改为:

#
# Library names and locations
CLNT_NAM=clntsh                      # (short) library name
CLNT_VER=9.0                        # library version number
CLNT_LIB=lib${CLNT_NAM}.so          # name of symlink to library
CLNT_LNK=${CLNT_LNK}.${CLNT_VER}    # actual library file name
LIB_DIR=${ORACLE_HOME}/${LIB}        # lib. destination directory

    第二步,运行genclntsh重新生成客户端的动态库,这一步不要在正在运行的机器上做.

    第三步,用gcc去编译程序时加上以下选项.

gcc -o ocidemo.bin ocidemo.c -I${ORACLE_HOME}/rdbms/demo -L${ORACLE_HOME}/lib -lclntsh -Wl,-Bdynamic

    第四步,编写一个Shell去执行OCI程序(ocidemo.bin)

#!/bin/sh

if [ "A${ORACLE_HOME}A" = "AA" ]; then
echo "ORACLE_HOME environment variable not setted."
exit
fi

if [ "A${LD_LIBRARY_PATH}A" = "AA" ];then
LD_LIBRARY_PATH=/lib:/usr/lib
fi

if [ -d ${ORACLE_HOME}/lib32 ]; then
LD_LIBRARY_PATH=${ORACLE_HOME}/lib32:${ORACLE_HOME}/lib:${LD_LIBRARY_PATH}
else
LD_LIBRARY_PATH=${ORACLE_HOME}/lib:${ORACLE_HOME}/lib64:${LD_LIBRARY_PATH}
fi

export LD_LIBRARY_PATH

ocidemo.bin $*

    我在RedHat Linux和Solaris上通过以上步骤解决OCI程序的运行库文件问题.

posted on 2008-04-17 01:04 RedLight 阅读(675) 评论(0)  编辑 收藏 引用 所属分类: ORM关系对象数据库架构


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2009年1月>
28293031123
45678910
11121314151617
18192021222324
25262728293031
1234567

导航

统计

公告


Name: Galen
QQ: 88104725

常用链接

留言簿(3)

随笔分类

随笔档案

相册

My Friend

搜索

最新评论

阅读排行榜

评论排行榜