C++类库:OTL通用的数据库连接类库

From: http://www.cppblog.com/lovefeel2004/archive/2010/06/02/116946.aspx


OTL是一个纯C++的通用数据库连接模板库,可以支持各种当下流行的数据库,如Oracle,Sybase, MySQL, PostgreSQL, EnterpriseDB, SQLite,  MS ACCESS, Firebird等等.它是一个跨平台类库,在MS Windows, Linux/Unix/Mac OS X 都可以使用。

下载网址:http://otl.sourceforge.net/

OTL使用简单, 只要头文件中包含有: #include "otlv4.h" 就可,实际上整个OTL就一个.H的文件,使用起来极为的方便。

OTL使用方法:

1、首先指定要连接的数据库类型,OTL用宏定义来指定要连接的数据库类型。OTL会根据这个宏定义来初始化数据库连接的环境。

相关的宏定义列表 http://otl.sourceforge.net/otl3_compile.htm

如: #define OTL_ORA8I 表示连接Oracle 8i 数据库。

 

2、例子

#include <iostream>
using namespace std;
#include <stdio.h>#define OTL_ORA8I // 指定连接的数据库类型
#include <otlv4.h> // include the OTL 4 header fileotl_connect db; // 定义数据库实例void insert()
// 添加记录{otl_stream o(50, // buffer size"insert into test_tab values(:f1<float>,:f2<char[31]>)",// SQL statementdb // connect object);char tmp[32];for(int i=1;i<=100;++i){
#if defined(_MSC_VER)
#if (_MSC_VER >= 1400) // VC++ 8.0 or highersprintf_s(tmp,sizeof(tmp),"Name%d",i);
#elsesprintf(tmp,"Name%d",i);
#endif
#elsesprintf(tmp,"Name%d",i);
#endifo<<static_cast<float>(i)<<tmp;}
}//查询记录void select()
{otl_stream i(50, // buffer size"begin ""  open :cur1 for ""   select * from test_tab ""   where f1>=:f<int> and f1<=:f*2; ""end;", // SELECT statement via referenced cursordb, // connect object":cur1" // referenced cursor placeholder name);// create select streamotl_column_desc* desc;int desc_len;i<<4; // Before the child SELECT statement can be described,// the PL/SQL master block needs to be executed.// Forcing the execution of the blcok by entering its input// patameter.desc=i.describe_select(desc_len);for(int n=0;n<desc_len;++n){cout<<"========== COLUMN #"<<n+1<<" ==========="<<endl;cout<<"name="<<desc[n].name<<endl;cout<<"dbtype="<<desc[n].dbtype<<endl;cout<<"otl_var_dbtype="<<desc[n].otl_var_dbtype<<endl;cout<<"dbsize="<<desc[n].dbsize<<endl;cout<<"scale="<<desc[n].scale<<endl;cout<<"prec="<<desc[n].prec<<endl;cout<<"nullok="<<desc[n].nullok<<endl;}}int main()
{otl_connect::otl_initialize(); // 初始化Oracle环境try{db.rlogon("scott/tiger"); // 连接Oracleotl_cursor::direct_exec(db,"drop table test_tab",otl_exception::disabled // disable OTL exceptions); // drop tableotl_cursor::direct_exec(db,"create table test_tab(f1 number, f2 varchar2(30))");  // create tableinsert(); select();}catch(otl_exception& p){ // intercept OTL exceptionscerr<<p.msg<<endl; // print out error messagecerr<<p.stm_text<<endl; // print out SQL that caused the errorcerr<<p.var_info<<endl; // print out the variable that caused the error}db.logoff(); //断开数据库连接return 0;
}


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/406203.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 报错3534_win7下安装MYSQL报错:MYSQL 服务无法启动的3534问题

win7下安装MYSQL,只到“net start mysql”这一步报错:3534的错误&#xff1a;是直接官网下载的压缩文件.不是安装文件.解决方法:1:环境变量PATH添加完成(例如&#xff1a;h:\mysql\\bin2:在mysql目录下&#xff0c;新建data目录。3:在mysql目录下 新建新建一个默认配置文件my.i…

Linux下Socket网络编程

什么是Socket Socket接口是TCP/IP网络的API&#xff0c;Socket接口定义了许多函数或例程&#xff0c;程序员可以用它们来开发TCP/IP网络上的应用程序。要学Internet上的TCP/IP网络编程&#xff0c;必须理解Socket接口。 Socket接口设计者最先是将接口放在Unix操作系统里面的。如…

软件测试课初感

在上课以前&#xff0c;说起软件测试&#xff0c;就连我们这些学了两年多的大学生&#xff0c;也会觉得“测试&#xff0c;不就是用一用&#xff0c;找找编写的时候没有发现的bug&#xff0c;然后就完事了”。 然而呢&#xff0c;改观就在第一节课上&#xff0c;直到老师老师举…

npm-shrinkwrap锁定依赖

npm-shrinkwrap锁定依赖

windows和linux下,查看oracle SID的方法

From: http://www.linuxdiyf.com/viewarticle.php?id78524 Windows 平台下&#xff1a;你可以到注册表去&#xff0c;看看 HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE 下面&#xff0c;有一个 ORACLE_SID。linux平台下&#xff1a;如果你的server是linux的话1.以安装oracle的账号…

Impress.js上手 - 抛开PPT、制作Web 3D幻灯片放映

前言&#xff1a; 如果你已经厌倦了使用PPT设置路径、设置时间、设置动画方式来制作动画特效、那么Impress.js将是你一个非常好的选择。 用它制作的PPT将更加直观、效果也是嗷嗷美观的。 当然&#xff0c;如果用它来装X&#xff0c;是需要付出一些代价的&#xff0c;不过如果你…

采用合适的网站优化技术

不久前读到一篇博文&#xff0c;讲述开心网存在的问题&#xff0c;列举了一些应该采用的网站优化技术。不得不说研究的 很有道理&#xff0c;博主细致并且较全面的分析了开心网的几个”缺点”&#xff0c;我在这里也不是想要反驳那篇博文的意思&#xff0c;只是想说&#xff0c…

mysql gtid 主主_mysql GTID主从复制(主库在线,添加新丛库)

要求&#xff1a;1、 主库上线&#xff0c;主库不停止服务的前提下做主从复制2、 新添加一个丛库操作&#xff1a;1、 在主库导出数据(主库正常运行)&#xff1b;2、 将主库的sql文件传到丛库&#xff1b;3、 丛库恢复数据库&#xff…

Mac-安装Homebrew报错error: could not lock config file .git/config:

Mac-安装Homebrew报错error: could not lock config file .git/config:

Qt中的QFileDialog类的几个示范代码

From: http://www.hedabbs.cn/thread-102600-1-1.html void Dialog::setExistingDirectory() { //选择一个文件夹; QFileDialog::Options options QFileDialog::DontResolveSymlinks | QFileDialog::ShowDirsOnly; if (!native->isChecked()) options…

JS 画饼图,折线图

网址&#xff1a; http://www.hcharts.cn/demo/index.php 效果图&#xff1a; 它的网址里面都很全的。简单实用扣代码即可 使用时注意数据格式即可 1         //获取mood_evalue的百分比2 $total_mood_evalue 0;3 //初始化key的数组&…

集群效应

FSK十连跳了&#xff0c;作为一个拥有60万人的集团企业。 有人非正常死亡也是正常的。我这里并不想讨论血泪模式。而是想引申这种软件模式的可能性。 从规模效应来说&#xff0c;作为老板&#xff0c;如果你从每个人身上每天获取一元的利润&#xff0c;一天就有60wRMB 的收入。…

mysql管理员就业_MySQL管理员必备的十大工具盘点

ySQL必备工具第一位: mk-query-digest没有什么比低下的MySQL性能表现更让人抓狂的了。尽管大家常常下意识地认为是硬件配置滞后导致此类问题&#xff0c;但事实上在大多数情况中真正的症结并不在这里。性能表现不佳往往由以下原因造成&#xff0c;即某些执行缓慢的查询阻塞了其…

webpack.DefinePlugin使用介绍

webpack.DefinePlugin使用介绍 webpack.DefinePlugin

vim、gvim在windows下中文乱码的终极解决方案

From: http://www.liuhuadong.com/archives/68/index.html vim、gvim在windows下中文乱码的终极解决方案 在windows下vim的中文字体显示并不好&#xff0c;所以我们需要调整字体显示编码为utf-8&#xff0c;只有这样才能使用美观的中文。这时候可能出现很多中文乱码。 如&#…

mysql业务繁忙时能建索引吗_MySQL DBA面试高频三十问

原标题&#xff1a;MySQL DBA面试高频三十问前言本文主要受众为开发人员,所以不涉及到MySQL的服务部署等操作,且内容较多,大家准备好耐心和瓜子矿泉水.前一阵系统的学习了一下MySQL,也有一些实际操作经验,偶然看到一篇和MySQL相关的面试文章,发现其中的一些问题自己也回答不好,…