FastDB的表对应于C++类
来源:互联网 发布:日本电装公司 知乎 编辑:程序博客网 时间:2024/04/30 21:36
FastDB的表对应于C++类,表中的记录对应类的实例,如果要建立自己的数据库文件或者查找、插入等,好像必须要先建好这些类,因为FastDB面向是对对象的操作而不是sql元组,每次查询的结果是来自一个类的对象的集合。如果是从一个xml文件中导入数据,就不需要建类,只要如下代码:
dbDatabase db;db.open(_T(“testdb”));
db.importDatabaseFromXml(_T("test.xml"));
但要访问里面的数据就要建类。下面是一个表的类的代码:
class Contract
{
public:dbDateTime delivery;
int4 quantity;
db_int8 price;
dbReference<Detail> detail;
dbReference<Supplier> supplier;
TYPE_DESCRIPTOR((
KEY(delivery, HASHED|INDEXED),
KEY(quantity, INDEXED),
KEY(price, INDEXED),
RELATION(detail, contracts),
RELATION(supplier, contracts)));
};
Delivery,quantity,price,detail,supplier都是关系的属性,
事实上还有一个oid(object identifier)属性,是在insert记录时系统自动分配的(oid_t dbDatabase::allocateId(int n))。
detail和supplier比较特殊,因为FastDB不支持join,
所以没有外键的设置,表之间是通过dbReference<T> t来联系的。TYPE_DESCRIPTOR是一个字段描述符。
KEY(name, index_type)索引字段。index_type必须是HASHED和INDEXED标志的组合。
当指定HASHED标志的时候,FastDB将为是用这个字段作为关键字的表创建一个hash表。
当指定INDEXED标志时,FastDB将创建为使用这个字段作为关键字的表创建一个T-tree.RELATION(reference, inverse_reference) 指定类(表)之间的一对一、一对多或者多对多的关系。reference和inverse_reference字段都必须是引用或者引用数组类型。
inverse_reference字段是一个包含了指向当前表的逆引用的引用表。
逆引用自动由FastDB更新并用于查询优化。在建好各表的类后,还必须用宏REGISTER(name)来注册数据库的表,使C++类与数据库表之间建立一个映像。它还提供了一个cli接口和Javacli 接口,还在学习中……
dbDatabase db;db.open(_T(“testdb”));
db.importDatabaseFromXml(_T("test.xml"));
但要访问里面的数据就要建类。下面是一个表的类的代码:
class Contract
{
public:dbDateTime delivery;
int4 quantity;
db_int8 price;
dbReference<Detail> detail;
dbReference<Supplier> supplier;
TYPE_DESCRIPTOR((
KEY(delivery, HASHED|INDEXED),
KEY(quantity, INDEXED),
KEY(price, INDEXED),
RELATION(detail, contracts),
RELATION(supplier, contracts)));
};
Delivery,quantity,price,detail,supplier都是关系的属性,
事实上还有一个oid(object identifier)属性,是在insert记录时系统自动分配的(oid_t dbDatabase::allocateId(int n))。
detail和supplier比较特殊,因为FastDB不支持join,
所以没有外键的设置,表之间是通过dbReference<T> t来联系的。TYPE_DESCRIPTOR是一个字段描述符。
KEY(name, index_type)索引字段。index_type必须是HASHED和INDEXED标志的组合。
当指定HASHED标志的时候,FastDB将为是用这个字段作为关键字的表创建一个hash表。
当指定INDEXED标志时,FastDB将创建为使用这个字段作为关键字的表创建一个T-tree.RELATION(reference, inverse_reference) 指定类(表)之间的一对一、一对多或者多对多的关系。reference和inverse_reference字段都必须是引用或者引用数组类型。
inverse_reference字段是一个包含了指向当前表的逆引用的引用表。
逆引用自动由FastDB更新并用于查询优化。在建好各表的类后,还必须用宏REGISTER(name)来注册数据库的表,使C++类与数据库表之间建立一个映像。它还提供了一个cli接口和Javacli 接口,还在学习中……
- FastDB的表对应于C++类
- MongoDB于SQL的对应
- Entity Framework中对应于Entity的代理类
- fastdb的REPLICATION SUPPORT
- fastdb的索引
- 使用fastdb的感受
- fastdb的缺陷
- FastDB的commit
- fastdb的资料
- 使用fastdb的感受
- fastdb的事务与恢复
- 注解中用于@target的方法annotation/--ElementType.METHOD,ElementType.TYPE对应方法,类接口
- 关于FF对应于IE的onpropertychange说明
- 利用map查找对应于key值的mapped value
- osg::stateattribute派生类速查,对应于OpenGL的状态变量
- Java 将数字123对应于中文的一二三
- hbase hfile中Key的类型对应于源码
- FastDB程序崩溃后的锁清理
- Amazon 电面 08/22/2011
- Android屏幕中隐藏标题栏和状态栏
- 利用Service实现android重启,切换输出制式
- Sql 语句纪实
- 用gcc编译静态库,动态库
- FastDB的表对应于C++类
- 私有构造函数 单例模式
- Python3.x和Python2.x的区别
- Extjs xtype值大全
- 很全的英语短语,可以防止你英文退化
- 比较静态变量与实例变量,及它们的应用
- SAP中如何建立F4搜索帮助
- js 父子窗口——showModalDialog()、showModelessDialog()方法的使用(2)
- ps制作透明圆角png