otl c mysql_OTL的使用

OTL可通过odbc,数据库本身的连接库如oci,与数据库进行交互,跨平台,跨数据库,api使用方便且仅只是个头文件,我一直都使用这个。 OTL的官网是:http://otl.sourceforge.net/ 里面例子文档什么的都相当全。 以OTL连接Oracle 11g为例,说明下在VS中的使用方式:

OTL可通过odbc,数据库本身的连接库如oci,与数据库进行交互,跨平台,跨数据库,api使用方便且仅只是个头文件,我一直都使用这个。

OTL的官网是:http://otl.sourceforge.net/ 里面例子文档什么的都相当全。

以OTL连接Oracle 11g为例,说明下在VS中的使用方式:

1. VS 编译环境设置

a. 在工程项目中引入otlv4.h头文件

b. 在vs中指定头文件目录:

C:\oracle\product\11.2.0\dbhome_1\OCI\include

c.指定 附加库目录:

C:\oracle\product\11.2.0\dbhome_1\OCI\lib\MSVC

d. 输入附加库:

oci.lib

2. 以普通用户连接Oracle数据库的例子:

#include #include #define OTL_ORA11G_R2 // Compile OTL 4.0/OCI11.2

#define OTL_ORA_UTF8

#include "otlv4.h" // include the OTL 4 header file

//#pragma comment(lib,"oci.lib")

using namespace std;

otl_connect oracledb;

int main(void)

{

//int OTLSession_mode = OCI_SYSDBA;

try{

otl_connect::otl_initialize();

oracledb.rlogon("system/xcldb@xcldb");

//.......

}catch(otl_exception &p)

{

cerr

a. 如果使用的Oracle oci是64位的,vs就要编译成64位的程序,如果编译成32位,会提示找不到Oracle的动态库。

b.因为Oracle连接数据库较慢,有些会使用多线程,这时要注意线程安全问题.

通过otl_initialize()函数设不同的参数来解决.

// Threaded_mode = 1 means the multi-threaded mode, 0 -- the single threaded mode

otl_connect::otl_initialize(0);

3. 用SYSDBA登录身份连接Oracle数据库

当SYS用户连接Oracle时,如果用普通用户会报"ORA-28009 应当以sysdba或sysoper建立sys连接"错误.

在session_begin中指定用户登录身份即可:

db.session_begin(m_strUser.c_str(),m_strPassword.c_str(),0,OCI_SYSDBA);

OCI_DEFAULT

OCI_SYSDBA -- in this mode, the user is authenticated for SYSDBA access.

OCI_SYSOPER -- in this mode, the user is authenticated for SYSOPER access.

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值