Welcome 微信登录

首页 / 数据库 / MySQL / Linux下OTL连接Oracle数据库

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/lib3.编译没有错误了 ,运行则提示“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)推荐阅读:OTL之Oracle开发总结  http://www.linuxidc.com/Linux/2011-10/45350.htmRMAN备份策略制定参考内容 http://www.linuxidc.com/Linux/2013-03/81695.htmRMAN备份学习笔记 http://www.linuxidc.com/Linux/2013-03/81892.htmOracle数据库备份加密 RMAN加密 http://www.linuxidc.com/Linux/2013-03/80729.htm更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12控制文件的备份与恢复(RMAN工具)CentOS下安装Oracle 10g相关资讯      Oracle数据库  OTL连接Oracle数据库 
  • Oracle数据库全球化  (03月01日)
  • Oracle数据库日期过滤方法性能比较  (02/02/2015 13:20:26)
  • Oracle数据库安装中端口被占用问题  (10/29/2014 07:42:24)
  • 在CentOS 6.6上搭建C++运行环境并  (10/10/2015 19:44:40)
  • Oracle数据库无法使用localhost和  (11/14/2014 16:39:10)
  • Oracle 多数据库的数据同时更新  (06/16/2014 21:52:23)
本文评论 查看全部评论 (0)
表情: 姓名: 字数