好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

解决Access连接accdb不可识别的数据库格式异常

在Access07之前的数据库后缀名均为*.mdb 而连接字符串写成 Provider= Microsoft.Jet.OLEDB.4.0 ;Data Source=C:\myFolder\*. mdb ;Persist Security Info=False; 但是Access07和Access10将后缀名改为了*.accdb。而通过上述连接的话就会报出"不可识别的数据库

在Access07之前的数据库后缀名均为*.mdb 而连接字符串写成 Provider= Microsoft.Jet.OLEDB.4.0 ;Data Source=C:\myFolder\*. mdb ;Persist Security Info=False;

但是Access07和Access10将后缀名改为了*.accdb。而通过上述连接的话就会报出"不可识别的数据库格式"异常。

需要注意的是 Microsoft.Jet.OLEDB.4.0 的Oledb的连接方式是比较老的连接方式,而07以后的Oledb连接方式将改成 Microsoft.ACE.OLEDB.12.0。

改后的连接变成了 Provider= Microsoft.ACE.OLEDB.12.0 ;Data Source=C:\myFolder\*. accdb ;Persist Security Info=False;



送给新手的一个小窍门:

在asp.net中经常把连接字符串写在web.config中。但是access的连接字符串是需要数据库的绝对位置。即 盘符:/文件夹/文件 这样就导致经常把文件拷贝后需要改路径的问题。其实完全可以通过程序来获得数据库文件的绝对路径。具体如下:

web.config中只写数据库文件名 (一般会把数据库文件放在App_Data文件夹下,因为有一定的安全性)

    appSettings  > 
add key ="ConnString" value ="App_Data\ManageDB.accdb" />
appSettings >

然后在DBHelper类获得字符串的写上如下方法:

  public   static   string  connectionString =  "  Provider=Microsoft.ACE.OLEDB.12.0; Data Source=  "  + AppDomain.CurrentDomain.BaseDirectory + ConfigurationSettings.AppSettings[ "  ConnString  " ]; 

通过AppDomain.CurrentDomain.BaseDirectory来获得此数据库的绝对路径.


查看更多关于解决Access连接accdb不可识别的数据库格式异常的详细内容...

  阅读:44次