Chinaunix首页 | 论坛 | 博客
  • 博客访问: 21779
  • 博文数量: 6
  • 博客积分: 190
  • 博客等级: 入伍新兵
  • 技术积分: 51
  • 用 户 组: 普通用户
  • 注册时间: 2011-09-02 10:34
文章分类

全部博文(6)

文章存档

2012年(2)

2011年(4)

我的朋友

分类: 数据库开发技术

2012-05-23 12:37:02

1, OTL是什么

OTL是一个数据库访问模板库,支持绝大部分数据库访问。OTL是C++写的,based on templates, 只有一个头文件,大小只有800K+。使用方便,性能也很不错

可以使用OTL访问基本上所有的数据库,在你更换数据库时不用修改任何业务代码

强烈推荐在C++开发中使用

 

2,OTL下载

~clr/doc/otl/otlv4_h.zip

 

3,OTL使用

参见OTL Samples: ~clr/doc/otl/otl3_examples.htm

 

4,多线程下使用OTL时几个注意的地方

1) static int otl_connect::otl_initialize(const int threaded_mode=0);

如果在多线程环境下使用,threaded_mode设置为1

注意:即使设置为1并不代表就是线程安全(thread-safe)

实际上OTL并不是线程安全的,一个otl_connect只能同时被一个线程使用,如果在多线程环境下使用OTL,需要自己保证otl_connect对象的线程安全

 

2)otl_stream_pool

OTL支持stream pool,就是一个池,在一个otl_stream close时,把它放到池中,下次访问时可以从池中获取,实现fast reopen,提高程序性能

注意:otl_stream_pool是otl_connect的一个成员,所以要在otl_connect锁unlock之前执行otl_stream.close,否则会出现那个啥:)

即使不使用otl_stream_pool,也要在otl_connect锁unlock之前执行otl_stream.close

 

经验证,OTL在多线程环境可以稳定运行

使用otl_stream_pool可以获得一定的性能提升

本文版权归作者 kanego 和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
阅读(2505) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~