日期:2014-05-16  浏览次数:20505 次

asp 数据库不能更新 数据库或对象为只读

Microsoft OLE DB Provider for ODBC Drivers 错误 '80004005',[Microsoft][ODBC Microsoft Access Driver] 不能更新,数据库或对象为只读。昨天开始要做asp网站了,一开始就遇到麻烦了,浏览每个网页都是说数据库不能更新,对象为只读,是500.100错误,试了很多方法终于找到了解决的方法,造成这个原因的问题就是站点目录的访问权限问题。因为在使用Access数据库的时候,要在同目录生成一个.ldb文件,如果此目录没有写权限或者Access数据库本身没有写的权限,那么就会***这个错误。

?

?

?

解决的方法:
由于通过浏览器访问网站大都使用Internet匿名访问,
我们只需要在数据库的目录权限里添加上“IUSR_计算机名”用户就可以了,分给它“写入”权限。我看过一些人说让加入EveryOne用户,并给“写入”权限,这个太危险了。原则上是此目录加的可以写入用户就是在IIS中配置的时候加的 Internet匿名访问用户,一般默认为“IUSR_计算机名”,不过如果是虚拟主机就要自己看看了。

?


具体的操作方式就是:

?


鼠标右键点击数据库所在目录(或者它上级目录,但是注意要能够继承权限)-〉选择“共享和安全”-〉选择“安全”选项卡-〉

?


点击“添加”按钮-〉点击“高级...”按钮-〉点击“立即查找(N)”按钮-〉找到前缀为“IUSR_”的用户名
(格式为IUSR_计算机名)-〉选中此用户,点击确定-〉这样这个用户就被加进来了-〉在“Internet来宾帐户”的权限框中,


除了默认的还要选中“写入权限”-〉“应用”或者“确定”即可。

ps:如果在文件夹上右击没有安全选项,您可以通过以下步骤来解决。

我的电脑-工具-文件夹选项-查看-使用简单文件共享(推荐)不要勾选。问题解决了,呵呵