首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DbEngine可从Access获得,但不能从.NET获得

DbEngine可从Access获得,但不能从.NET获得
EN

Stack Overflow用户
提问于 2017-09-28 06:49:51
回答 1查看 1.1K关注 0票数 2

我的.NET应用程序正在使用MS数据库,并使用"Microsoft数据库引擎数据访问对象库“(ACEDAO.DLL)读取数据库。但是,只有在安装Microsoft数据库引擎时,它才能工作。我的目标是避免它。例如,目前我已经安装了Office 2013 x64并安装了Access,但它无法工作。

如果我添加COM引用和/或使用Microsoft.Office.Interop.Access.Dao.dll -它在未注册的COMException CLSID {CD7791B9-43FD-42C5-AE42-8DD2811F0419}中失败。

如果我尝试使用与Type.GetTypeFromProgID("DAO.DBEngine.120")的后期绑定-它将返回null。

不管我如何构建应用程序-- AnyCPU、x86、x64 --它都不起作用。

同时,在同一台电脑上,如果我做同样的事情,从访问-它工作!我可以两者兼得

代码语言:javascript
复制
Set dbe = New DBEngine
Set db = dbe.OpenDatabase(filePath)

代码语言:javascript
复制
Set dbe = CreateObject("DAO.DBEngine.120")
Set db = dbe.OpenDatabase(filePath)

它不会失败。

请不要建议安装Microsoft数据库引擎或Access运行时。这不是我要找的。我只是想了解为什么从Access获得的东西不能从功能更强大的.NET中获得,并且我如何在不需要安装任何其他东西的情况下修复这个问题?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-04-14 18:40:10

事实证明,这个答案就是等待3年。正如Simon在评论我的问题时提到的- ACE/DAO库“处于泡沫中”,可供Office使用,但不能用于外部应用程序。最后,在2020年,MS决定再次提供它们:从泡沫中打破ACE

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

https://stackoverflow.com/questions/46462678

复制
相关文章

相似问题

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