vc6.0使用DAO访问access2000的问题

本文介绍了在使用VC6.0和MFC的DAO类操作Access2000时遇到的'无法识别数据库格式'问题。问题根源在于DAO3.5的Jet3.5引擎无法支持Access2000的Jet4.0引擎。解决方案包括动态链接MFC时更新DLL版本和静态链接时升级MFC库。动态链接可通过设置AfxGetModuleState()->m_dwVersion为0x0601;静态链接则需要修改Daocore.cpp源文件并重新编译MFC库。
摘要由CSDN通过智能技术生成

感觉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

VC DAO 操作Access的测试例子,本演示是VC 使用DAO连接Access数据库的一个测试程序,学习如何使用DAO操作Access,通过添加一个数据库记录来演示添加、删除、插入数据的例子,比较简单,面向VC 初学者的一个例子。部分代码分享如下:   // 取得被选择记录的索引   nIndexInFieldList = m_listctrlInfo.GetNextSelectedItem(pos);   // 高亮被的选择记录   m_listctrlInfo.SetFocus();   // 从文件中把当前行记录删除   // 获取数据库文件   m_csDatebaseFile = GetDatabaseFile();   // 判断数据库是否已经打开   if (!m_bIsOpenDB)   {    db.Open(m_csDatebaseFile);    // 判断数据集是否已经打开    if (!m_bIsOpenDSN)    {    RecSet.Open(AFX_DAO_USE_DEFAULT_TYPE,"SELECT * FROM PositionTable",NULL);    }   }   m_nTotal = m_listctrlInfo.GetItemCount();   m_nCurrentIndex = ConvertIndex(nIndexInFieldList,m_nTotal - 1);   RecSet.MoveFirst();   RecSet.Move(long(m_nCurrentIndex));   RecSet.Delete();   ClearContent();   // 删除被的选择记录   m_listctrlInfo.DeleteItem( nIndexInFieldList );   // 显示删除数据成功的信息   GetDlgItem(IDC_STATIC_INFO)->SetWindowText(_T("删除数据成功!"));   // 再次取得第一条记录的位置   POSITION pos = m_listctrlInfo.GetFirstSelectedItemPosition();   UINT flag = LVIS_SELECTED|LVIS_FOCUSED;   m_listctrlInfo.SetItemState( nIndexInFieldList, flag, flag );
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值