时间:2021-07-01 10:21:17 帮助过:3人阅读
记录(Record)做好后,表(Table)就简单了。
基本上表要做的工作就是对记录的管理,增删改查那一套。
到了这里,基本上需要的功能都差不多了,目前能想到的就是这些。下一步打算是把代码优化一下,更稳健一些,毕竟里面大量使用了指针,很有可能在哪个角落里没有处理好对象的创建、删除,会导致后面程序的不健壮。然后就是把接口再优化一下,做一些Demo程序,来规范本数据库的使用。没问题了就可以考虑ERP了。
当然,在写ERP的时候肯定会对数据库提出各种各样的要求,到时候肯定会再回过头来修改这个数据库的。
// 为LzjSchema的实例
/* LzjTable在硬盘中的格式:
part1: 本LzjTable的名称
part2: 本表所用的模式的名称
part3: m_recordList
*/
class LzjTable{
public:
LString m_strName;
LzjSchema *m_pSchema; // 本表所用的模式
LList<LzjRecord*> m_recordList;
public:
LzjTable(LString strName);
LzjTable(LString strName, LzjSchema *pSchema);
~LzjTable();
void Add(LzjRecord *pRecord); // pRecord为内生变量
LzjRecord* Get(DWORD dwIndex); // From 0
void Delete(DWORD dwIndex);
void Update(DWORD dwIndex, LzjRecord *pRecord);
DWORD Serialize(LFile *pFile); // 序列化
DWORD Unserialize(LFile *pFile); // 反序列化
void ConsoleOut(std::ostream *pCout);
};
从零开始实现一个最简单的数据库_Step4:Table
标签: