介绍一个C++的ORM工具ODB(一)
前段时间了解了下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手册,在这里
介绍基本使用方法的小例子下次再写,先把本周两门考试应付了再说
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)