前段时间了解了下ORM(对象关系映射),然后就找了下C++的ORM框架,发现真的是很少,主要就下面几种

名称 开源 License 需要特定的框架支持 支持Qt 支持Boost 支持MySQL 支持PostgreSQL 支持SQLite 支持XML 支持Oracle 支持MSSQL Server 支持ODBC 支持IBM DB2
LiteSQL Yes BSD no Yes   Yes Yes Yes          
ODB Yes GPL/other no Yes Yes Yes Yes Yes   Yes      
QxOrm Yes LGPL yes, Qt Yes Yes Yes Yes Yes   Yes Yes Yes Yes
Wt::Dbo Yes GPL / commercial yes, Wt No Yes Yes Yes Yes No No No No No

LiteSQL用xml定义表单,而且感觉它好像是把所有库的支持都写到一个动态链接库里面去了,所以比较庞大,QxQrm、Wt::Dbo又依赖于特定的框架。所以综合考虑,感觉ODB最适合用来开发了。官网传送门

ODB支持特性

  • 自动生成数据库支持的代码(跨数据库)
  • 能够处理任何的标准C++代码(无开发平台限制)
  • 根据类的定义,编译生成数据库表单(可在Visual Studio中配置编译命令)
  • 表单是以独立的SQL文件,或者嵌入C++的SQL代码的形式存在的
  • 支持面向对象的持久化模型和数据库API(提供简单易用的数据库操作方法)
  • 支持基于表达式或者类型安全的对象查询语言
  • ODB使用了版本控制
  • 支持执行本地SQL语言
  • 支持SQL跟踪(输出窗口可实时输出当前执行的SQL语句)
  • 跨平台,提供连接池保证线程安全

关于映射

  • 默认映射所有基本的C++类型和std::string
  • 自动映射C++的枚举对象到数据库的ENUM类型或者整型
  • 支持映射BLOB类型到std::vector
  • 支持合成值类型(自动解析成多字段)
  • 支持NULL语义映射到智能指针,诸如odb::nullable or boost::optional.
  • 支持分配表名到持久类
  • 支持分配字段名到数据成员
  • 支持映射C++类型到数据库类型
  • 支持自动赋值的对象id
  • 支持没有id的持久化类
  • 支持只读/常量数据成员
  • 支持使用自定义的智能指针作为object/view/value的指针
  • 支持cache技术(使用session)

具体使用可以见官方的odb手册,在这里


写了个小例子,全面地感受了下ODB(1.7.0版)。总体来说还是不错,不过应用到实际的项目中,问题还是比较大。

首先是不支持联合主键,而且没有CHECK约束、UNIQUE约束,这是官方都承认的。

虽然提供了延迟加载(lazyload)来改善效率,不过使用起来不方便

查询不灵活,只能在WHERE之后的部分设定查询条件,像查询存在(SELECT EXISTS)、查询数量(SELECT COUNT)都必须定义一个视图来实现,实在麻烦

批量删除比较慢,而且不灵活。高级一点只提供了按查询条件删除,但是这是远远不够的,虽然开放了执行SQL的接口,但是这样就破坏了ORM工具设计的初衷,也为以后维护带来了麻烦。

有触发器对应的功能(即软件实现),提供了callback(回调),支持触发器常用的事件,删除前后、新增前后等。不过我尝试添加一个删除触发另外一个表的数据删除编译失败了,不知为何

没有存储过程、游标对应的软件实现

 

下面是附件源码的运行结果:

附件下载:

http://dl.dbank.com/c07l5w5k7x

(需要去官网下载ODB编译并加入到VC目录下,推荐使用VS2008SP1以上版本的IDE,或者使用boost库,因为需要用到智能指针)