当前位置:Gxlcms > 数据库问题 > 从零开始实现一个最简单的数据库_Step4:Table

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

时间: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

标签:

人气教程排行