Linux下OTL连接Oracle数据库

#include <iostream> 
using namespace std; 

#define OTL_ORA10G 	//不可缺少
#include "otlv4.h"	//注意OTL头文件位置

otl_connect db; 

int main() 
{ 
    otl_connect::otl_initialize();  
    try 
    { 
        db.rlogon("user/passwd");  //连接本机数据库
		if(db.connected)
       		cout<<"Connected to Database"<<endl; 
    } 
    catch(otl_exception& p) 
    {   
        cerr<<p.msg<<endl;   
        cerr<<p.stm_text<<endl;  
        cerr<<p.sqlstate<<endl;  
        cerr<<p.var_info<<endl;  
    }

    db.logoff(); 
 	return 0; 
} 

上面是一段很挫的OTL连接Oracle数据库代码,只有连接没有其它操作。但是我在编译时遇到了些问题:会产生一坨错误提示,但其实真正问题不多。具体如下:(PS:我的Oracle 10g已经正确的安装在本地)

1. 首先是提示找不到"oci.h", 这个文件其实位于$ORACLE_HOME/rdbms/public下,解决方法有多种,可以g++编译时使用"-I"头文件路径,我是把路径添加到了CPLUS_INCLUDE_PATH这个环境变量中

2.继续编译会有如下错误提示

undefined reference to `OCIServerDetach'

undefined reference to `OCIHandleFree'

这是因为没有连接libclntsh.so这个库文件,这个文件位于$ORACLE_HOME/lib下,知道原因解决方法就很简单了,命令如下

g++ otl_example.cpp -lclntsh -L$ORACLE_HOME/lib

3.编译没有错误了 ,运行则提示“error while loading shared libraries: libclntsh.so.10.1: cannot open shared object file: No such file or directory”

解决方法:export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib


至此,这个小程序就可以正常运行了。(我的ORACLE_HOME:/oracle/oracle/product/10.2.0/db_1)





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值