otl c mysql_OTL的使用
发布日期:2021-06-24 01:38:24 浏览次数:13 分类:技术文章

本文共 1518 字,大约阅读时间需要 5 分钟。

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中文网,转载请注明出处,感谢您的尊重!

转载地址:https://blog.csdn.net/weixin_29306261/article/details/113341471 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:您访问的网页出错了! 网络连接异常、网站服务器失去响应_造成Baiduspider(百度蜘蛛)抓取网站异常的原因有哪些...
下一篇:mysql 归类_MySQL 获取所有归类和每个分类的前几条记录

发表评论

最新留言

路过,博主的博客真漂亮。。
[***.116.15.85]2024年03月16日 15时57分27秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

有至少一个用MySQL_Mysql有用的面试题 2019-04-21
mysql select同时update_MySQLSELECT同时UPDATE同一张表 2019-04-21
mysql删除后数据库没变化_mysql之delete删除记录后数据库大小不变 2019-04-21
net mysql start3534_MySQL 5.7.14 net start mysql 服务无法启动-“NET HELPMSG 3534” 的奇怪问题... 2019-04-21
pta两个有序链表的合并_7-1 两个有序链表序列的合并 (20分) --- 内存问题再叙 2019-04-21
python问题描述怎么写_python写文件有时候写不进去怎么办 2019-04-21
qpython3安装lxml_在python的lxml中使用xml目录? 2019-04-21
java 幂取模_快速幂取模算法 2019-04-21
java build path jre_java-如何在安装了jre 7后为Jre 6设置路径? 2019-04-21
java上传下载源码_javaweb简单实现文件上传与下载源代码 2019-04-21
java socket udp 广播_1.Java 的屏幕广播(基于UDP),2.多线程下载器 2019-04-21
java控制热敏打印机的例子.rar_stm32控制热敏打印机 2019-04-21
java clone equals_(原)java中对象复制、==、equals 2019-04-21
java滚动字幕实训报告_Java实习报告 (7000字).doc 2019-04-21
php7 memcached.exe,PHP7 下安装 memcache 和 memcached 扩展 2019-04-21
计算机二级java技巧,计算机二级报java难考吗 2019-04-21
php foreach 数据库,php – 使用foreach将数据库检索的数据排列在HTML表中 2019-04-21
拉格朗日matlab编程例题,Matlab习题讲解.doc 2019-04-21
case是不是php语言关键字,PHP语言 switch 的一个注意点 2019-04-21
linux php mkdir失败,linux – mkdir错误:参数无效 2019-04-21