首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

简易内存数据库(4)CREATE

2012-12-18 
简易内存数据库(四)CREATE因为整个程序都是围绕Table的,为了方便起见,我申明了一个全局变量Table t??我们

简易内存数据库(四)CREATE

因为整个程序都是围绕Table的,为了方便起见,我申明了一个全局变量

Table t;

??

我们一个单词一个单词的读取文件内容。然后一个单词一个单词的进行比较。

临时的内容保存在char buffeer[100]中。

有时候需要的内容就直接保存在相应的table内存块中。

?

创建代码如下

/* * 描述:根据给定文件,在内存里填充数据库格式 * 参数:已经打开的文件 * 返回:返回0说明创建失败。返回1则创建成功 */int createTable(FILE *fp){//先把要填充的内容清空memset(&t, 0, sizeof(Table));char buffer[100];//第一次读应该读到createfscanf(fp,"%s",buffer);if (stricmp(buffer,"create")) return 0; //第二次读应该读到tablefscanf(fp,"%s",buffer);if (stricmp(buffer,"table")) return 0; //第三次读应该读到表名fscanf(fp,"%s",t.name);//第四次读应该读到(fscanf(fp,"%s",buffer);if (strcmp(buffer,"(")) return 0; //接下去开始读column内容

其中有2个函数解释一下

1)memset?。看名字就知道,是memory set。设置内存的内容。memset(&t, 0, sizeof(Table))就是把&t指向的地址后的sizeof(Table)长度的字节设置成0

2)stricmp。 strcmp是两个字符串比较. stricmp是两个字符串不分大小写的比较。

热点排行