程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> 64位系統使用Access 數據庫文件的徹底解決方法,access徹底解決

64位系統使用Access 數據庫文件的徹底解決方法,access徹底解決

編輯:C#入門知識

64位系統使用Access 數據庫文件的徹底解決方法,access徹底解決


最近,有PDF.NET用戶問我怎麼在64位系統下無法訪問Access數據庫的問題,我第一反應是我怎麼沒有遇到呢?今天一看自己的VS和Office都是32位版本的,所以在VS裡面調試訪問Access是沒有問題的,但是直接使用編譯好的.NET程序訪問Access,就出問題了,報:

    未在本地計算機上注冊“Microsoft.Jet.Oledb.4.0”提供程序。

    於是,又在公司的電腦上(Win7 64位)做了實驗,發現跟家裡面的Win8.1 64位 問題一樣,上網搜索了一下,大部分都建議將.NET程序編譯的時候,目標平台設定為 x86 ,我試了下,果然成功。

    但是,如果你的.NET程序是別人編譯好的,且在64位系統上運行,要訪問Access數據庫,怎麼辦呢?

    首先想到,看能否通過應用程序配置文件,將.NET程序配置成運行在 32位 系統下,找了很久資料,無果,放棄。

    再想想,是不是跟自己的Office是32位有關呢?

    關鍵問題不在於是Access 2010還是Access 2013而已,不必鑽牛角尖,何不求其次,安裝一個Access 2007/2010的Database Engine不就行了。

 

解決辦法:

①   下載安裝Microsoft Access Database Engine 2010 Redistributable(28MB),共有32bit(下載)和64bit(下載)兩個版本,具體要安裝哪個要看你的Office程序是32bit的還是64bit的,比如:我的PC是64bit的Win8 Pro,但是我Office的程序是32bit的,所以我應當安裝AccessDatabaseEngine.exe(32bit);

②   打開你的.NET應用程序配置文件(應用程序名.config,Web應用程序為 Web.config),設置數據庫連接字符串的Provide Microsoft.ACE.OLEDB.12.0,例如標准連接字符串為:"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=Data.accdb;Persist Security Info=False;"

再次運行程序,OK,數據庫連接成功,一切正常。

注意:64位系統下一定要修改提供程序為 Microsoft.ACE.OLEDB.12.0,而此時的文件名,可以是 早期的 mdb文件,也可以是新的 accdb 文件。

        如果你雖然是64位系統,但是你的Office 是32位的,所以你只能安裝32位的ACE驅動,因此你的.NET應用程序也只能發布成32位的,如果編譯成anycpu版本,還是無法訪問ACE。

        (PS:如果你發布成x86格式的目標平台,並且不想使用accdb格式的Access數據庫文件,那麼就不必安裝上面的32位ACE驅動了,省得折騰:-《)

 注意:

      如果你安裝了 64位的Access程序,但是在VS2013中調試Web網站應用程序的時候,提示“Microsoft.ACE.OLEDB.12.0” 未注冊,請在VS的選項中,項目和解決方案,Web項目,勾選64位的 IIS Express 。

轉自:http://www.cnblogs.com/bluedoctor/p/3925871.html

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved