adox创建mdb数据库不可识别

adox创建mdb数据库不可识别,第1张

预计该数据库文件被损坏,

拔掉U盘读取和写入数据库中的数据,它是容易损坏的数据库文件中的一个小头,尾,如果你是编程每次应将该文件复制到同一目录,你连接到数据库,浩恢复的情况下损坏。

在Access07之前的数据库后缀名均为*.mdb 而连接字符串写成Provider=Microsoft.Jet.OLEDB.4.0Data 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.0Data Source=C:\myFolder\*.accdbPersist 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.0Data Source=" + AppDomain.CurrentDomain.BaseDirectory + ConfigurationSettings.AppSettings["ConnString"]

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

我碰到过一种,是数据库加密了,

你去下载一个二进制编辑软件如:ultra

edit

用这个软件打开,可以看到二进制内容,不要随便修改

然后跟你备份的数据库比较就可以查出不同了,具体的你到BAIDU去搜索ACCESS加密吧


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6683439.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-26
下一篇 2023-03-26

发表评论

登录后才能评论

评论列表(0条)

保存