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

名称 开源 License 需要特定的框架支持 支持Qt 支持Boost 支持MySQL 支持PostgreSQL 支持SQLite 支持XML 支持Oracle 支持MSSQL Server 支持ODBC 支持IBM DB2
LiteSQLYesBSDnoYes YesYesYes     
ODBYesGPL/othernoYesYesYesYesYes Yes   
QxOrmYesLGPLyes, QtYesYesYesYesYes YesYesYesYes
Wt::DboYesGPL / commercialyes, WtNoYesYesYesYesNoNoNoNoNo

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手册,在这里

介绍基本使用方法的小例子下次再写,先把本周两门考试应付了再说