OTL的使用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了OTL的使用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2028字,纯文字阅读大概需要3分钟。
内容图文
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<<p.msg<<endl; cerr<<p.stm_text<<endl; cerr<<p.var_info<<endl; } oracledb.logoff(); return 0; }
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.
内容总结
以上是互联网集市为您收集整理的OTL的使用全部内容,希望文章能够帮你解决OTL的使用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。