前段时间了解了下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<char>
- 支持合成值类型(自动解析成多字段)
- 支持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库,因为需要用到智能指针)
所有评论(0)