介绍一个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手册,在这里
介绍基本使用方法的小例子下次再写,先把本周两门考试应付了再说