为了账号安全,请及时绑定邮箱和手机立即绑定

请问Microsoft.ACE.OLEDB.12.0提供程序未注册

/ 猿问

请问Microsoft.ACE.OLEDB.12.0提供程序未注册

波斯汪 2019-09-06 12:06:51

Microsoft.ACE.OLEDB.12.0提供程序未注册

我有一个带有两个项目的Visual Studio 2008解决方案(一个Word-Template项目和一个用于测试的VB.Net控制台应用程序)。这两个项目都引用一个数据库项目,该项目打开与MS-Access 2007数据库文件的连接,并引用System.Data.OleDb。在数据库项目中,我有一个函数,它按如下方式检索数据表

 private class AdminDatabase
   ' stores the connection string which is set in the New() method
   dim strAdminConnection as string
   public sub New()
   ...
   adminName = dlgopen.FileName
   conAdminDB = New OleDbConnection
   conAdminDB.ConnectionString = "Data Source='" + adminName + "';" + _
       "Provider=Microsoft.ACE.OLEDB.12.0"
   ' store the connection string in strAdminConnection
   strAdminConnection = conAdminDB.ConnectionString.ToString()
   My.Settings.SetUserOverride("AdminConnectionString", strAdminConnection)
   ...
   End Sub
   ' retrieves data from the database
   Public Function getDataTable(ByVal sqlStatement As String) As DataTable
        Dim ds As New DataSet
        Dim dt As New DataTable
        Dim da As New OleDbDataAdapter
        Dim localCon As New OleDbConnection
        localCon.ConnectionString = strAdminConnection
        Using localCon
            Dim command As OleDbCommand = localCon.CreateCommand()
            command.CommandText = sqlStatement
            localCon.Open()
            da.SelectCommand = command
            da.Fill(dt)
            getDataTable = dt
        End Using
    End FunctionEnd Class

当我从我的Word 2007模板项目中调用此函数时,一切正常; 没有错误。但是当我从控制台应用程序运行它时会抛出以下异常

ex = {“'Microsoft.ACE.OLEDB.12.0'提供程序未在本地计算机上注册。”}

两个项目具有相同的引用,并且控制台应用程序在我第一次编写时(前一段时间)确实有效,但现在它已停止工作。我必须遗漏一些东西,但我不知道是什么。有任何想法吗?


查看完整描述

3 回答

?
蓝山帝景

我有Visual Basic 2008的Visual Basic程序使用Access 2007数据库并收到相同的错误。我找到了一些线程,如果你运行的是64位系统,建议将高级编译配置更改为程序属性中的x86。到目前为止,我的程序没有任何问题。

查看完整回答
反对 回复 2019-09-10
?
牧羊人nacy

基本上,如果您使用的是64位计算机,则IIS 7(默认情况下)不会为数据库引擎运行的32位应用程序提供服务。所以这正是你做的:

1)确保安装了2007数据库引擎,可以从以下网址下载:http://www.microsoft.com/downloads/details.aspx?FamilyID = 7554F536-8C28-4598-9B72-EF94E038C891&displaylang = en

2)打开IIS7管理器,然后打开“应用程序池”区域。在右侧边栏上,您将看到一个选项“设置应用程序池默认值”。单击它,将弹出一个包含选项的窗口。

3)默认情况下,第二个字段向下,即“启用32位应用程序”可能设置为FALSE。只需单击“false”所在的位置即可将其更改为“true”。

4)重新启动您的应用程序池(您可以通过按RECYCLE而不是STOP然后START来执行此操作,这也将起作用)。

5)完成后,您的错误消息将消失。



查看完整回答
反对 回复 2019-09-10
?
慕的地10843

您运行的是64位系统,数据库运行32位但控制台运行64位吗?没有运行64位的MS Access驱动程序,并且会报告与您报告的错误相同的错误。

查看完整回答
反对 回复 2019-09-10
  • 3 回答
  • 0 关注
  • 133 浏览
我要回答

添加回答

回复

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信