感觉DAO已经是一种比较旧的数据库技术,但我的一个同学还在使用VC6.0跟mfc的DAO类来操作access2000,并遇到了一个问题,就是程序运行时提示说“无法识别数据库格式”。
查了一下原因,应该是这样的:
VC6.0里面的mfc默认使用的是DAO3.5,而DAO3.5使用的数据库引擎是Jet3.5,Jet3.5操作access97是没有问题的,而操作access2000却不行,因为access2000使用的数据库引擎是Jet4.0,而Jet3.5够不上Jet4.0,它识别不了access2000里面的mdb。
DAO3.6使用的数据库引擎是Jet4.0,所以,为了操作access2000或所有的access数据库格式,可以考虑把MFC的DAO升级到3.6。
由于使用MFC有动态跟静态两种方式,所以这里要考虑两种升级MFC DAO的方法:
如果是使用动态链接MFC的方式,则只需要在程序执行初始化时(或在使用DAO之前),把mfc dll给升一下级即可---在程序中加上这一句:
AfxGetModuleState()->m_dwVersion = 0x0601; // 更新mfc为6.01版本
如果是使用静态链接mfc的方式,由于使用的是lib而不是运行时的dll,所以上面的函数明显不起作用。这时要考虑的是把mfc lib给升级(而不是dll)。升级mfc lib意味着修改原代码并再新编译。
首先,找到Daocore.cpp文件(源文件都在MFC/SRC下),在文件里面这个地方:
// Determine whether to use DAO 3.6, 3.5, or 3.0
// Use DAO 3.0 if DLL bui