首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Microsoft.ACE.OLEDB.12.0提供程序无法再在Windows8下打开.mdb

Microsoft.ACE.OLEDB.12.0提供程序无法再在Windows8下打开.mdb
EN

Stack Overflow用户
提问于 2013-01-28 20:58:45
回答 6查看 92.3K关注 0票数 12

我有一个使用Microsoft.ACE.OLEDB.12.0提供程序在Windows7 ( x64 )上读取MS Access数据库的x64应用程序,它工作正常(安装了Office2010)。

在安装了Office 2013的Windows 8下运行的同一应用程序失败,并显示一条消息,指出提供程序无法打开以前的版本。

在安装了Office 2013的Windows 8下,也有Microsoft.ACE.OLEDB.15.0,但我仔细检查了我的代码,确保它在连接字符串中指定了12.0。

这个provider -or有不同的“版本”吗?是不是我错过了什么?

我已经在Windows8下重新编译了一个使用x86平台的测试程序,并将提供者更改为Microsoft.Jet.OLEDB.4.0,它又可以正常工作了。不幸的是,该模块是一个更大的生态系统的一部分,需要能够在x64下运行(特别是excel的插件),而access数据库是由套件通过应用程序从供应商的网站下载的,因此转换数据库或将所有内容都更改为x86是不切实际的。

提前谢谢。

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2013-01-28 21:41:21

我突然想到检查每个提供程序使用的文件版本,并在注册表中查找,发现在安装了Office 2013的全新Windows 8安装下,两个提供程序都指向相同的程序集。

(C:\Program Files\Common Files\microsoft shared\OFFICE15\ACEOLEDB.DLL)

然后,我下载并运行了Microsoft Access数据库引擎可再发行程序(http://www.microsoft.com/en-us/download/details.aspx?id=13255),该程序随后将12.0提供程序的正确版本安装到C:\Program Files\Common Files\microsoft shared\OFFICE14\ACEOLEDB.DLL中,应用程序运行正常。

这似乎很奇怪,微软已经包括了一个品牌为12.0的提供商,它的行为不再像12.0了。

无论如何-希望这能帮助那些4-5个小时的头发拉扯的人…

克雷格

票数 15
EN

Stack Overflow用户

发布于 2014-06-11 02:13:39

安装较旧的Access的问题是,下次在Office2013中运行Access时,Office将“修复”自己,并将版本12的指针切换回Office15目录。

票数 5
EN

Stack Overflow用户

发布于 2014-05-23 16:12:12

只是为了澄清OP所描述的行为:

对于Office 2013 (ACE 15.0),Microsoft取消了对使用Jet 3.x和更早版本(即Access 97和更早版本)创建的mdb文件的支持。因此,我强烈假设导致问题的OP数据库是Access97-DB。Jet4.0数据库(Access 2000和.mdb)仍然受支持,不会产生任何错误。

Office 2013也将其较新的驱动程序注册为较早的版本,这是MS故意尝试保持许多程序和脚本正常运行的事实,这些程序和脚本具有内置的硬编码提供程序名称。正如你在升级时认识到的那样,这只是让many工作,而不是...

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14562587

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档