我的.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 --它都不起作用。
同时,在同一台电脑上,如果我做同样的事情,从访问-它工作!我可以两者兼得
Set dbe = New DBEngine
Set db = dbe.OpenDatabase(filePath)和
Set dbe = CreateObject("DAO.DBEngine.120")
Set db = dbe.OpenDatabase(filePath)它不会失败。
请不要建议安装Microsoft数据库引擎或Access运行时。这不是我要找的。我只是想了解为什么从Access获得的东西不能从功能更强大的.NET中获得,并且我如何在不需要安装任何其他东西的情况下修复这个问题?
发布于 2021-04-14 18:40:10
事实证明,这个答案就是等待3年。正如Simon在评论我的问题时提到的- ACE/DAO库“处于泡沫中”,可供Office使用,但不能用于外部应用程序。最后,在2020年,MS决定再次提供它们:从泡沫中打破ACE
https://stackoverflow.com/questions/46462678
复制相似问题