你的位置:首页 > 数据库

[数据库]从零开始实现一个最简单的数据库_Step4:Table


记录(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);};