现在位置:中国IDC吧>网页设计>Dreamweaver教程> 文章内容

DW做ASP程序时关于数据库的几个常见问题

收藏发布 来源:互联网 作者:中国IDC吧 更新日期:2008-09-30 点击:

  2 在上传文件时,因打开数据库造成的错误,如图四所示:

  
图四

  四、不能更新。数据库或对象为只读/操作必须使用一个可更新的查询 (80004005)

  Microsoft OLE DB Provider for ODBC Drivers 错误 '80004005'

   操作必须使用一个可更新的查询。

  Microsoft OLE DB Provider for ODBC Drivers 错误 '80004005' 不能更新。数据库或对象为只读。

  1、最普遍的原因是匿名用户帐号(IUSR_MACHINE)对该数据库文件没有写权限。要解决这个问题,在管理器中调整数据库文件的属性,让匿名用户有正确的权限。当使用ACCESS数据库时,不仅要给文件写的权限,还要给该目录写的权限.在IIS里面,有一个设置,就是Web匿名访问用户,也就是大家熟悉的 IUSR_。给你的Access数据库文件增加 IUSR_ 的改写权限。

  1) 这就是我们要用程序去操作的Access数据库文件

  2) 右键 --> 属性:此文件的“安全”属性

  3) 增加用户 IUSR_

  4) 设置 IUSR_ 对Access数据库文件的访问权限

  这是设置好了的权限注意只给了 IUSR_ 的读、写权限哦。不要给 Everyone 权限,而且还要给执行(Execute) 权限,这样容易被人家上传了ASP木马,然后执行,你的系统最高级的权限就被入侵者获取了。

  2、原因是数据库没有使用正确的模式打开。应该使用下面的方法打开。

SetConn=Server.CreateObject("ADODB.Connection")
Conn.Mode=3'3=adModeReadWrite
Conn.Open"myDSN"
Conn.Execute(SQL)
Conn.Close

  注意默认的Mode是设置0(adModeUnknown),它是允许更新的。

  3、还有可能是在ODBC管理器中将该DSN的只读选项选中。

  4、你是在同时更新两个表中的字段,也会出现这个错误信息,解决办法是分开来更新这两个表中各自字段。

  5、当你使用了一个从低版本中(如ACCESS2.0,ACCESS7.0)载入到高版本(ACCESS 2000)中的查询时,在执行这个查询是会出现该错误。

  五、Microsoft JET Database Engine 错误 '80040e09'

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

  A: 未打开数据库目录的读写权限。 解决方法:

  ( 1 )检查是否在 IIS 中对整个网站打开了 “ 写入 ” 权限,而不仅仅是数据库文件。

  ( 2 )检查是否在 WIN2000 的资源管理器中,将网站所在目录对 EveryOne 用户打开所有权限。具体方法是:打开 “ 我的电脑 ”---- 找到网站所在文件夹 ---- 在其上点右键 ---- 选 “ 属性 ”----- 切换到 “ 安全性 ” 选项卡,在这里给 EveryOne 用户所有权限。

  注意: 如果你的系统是 XP ,请先点 “ 工具 ”----“ 文件夹选项 ”----“ 查看 ”----- 去掉 “ 使用简单文件共享 ” 前的勾,确定后,文件夹 “ 属性 ” 对话框中才会有 “ 安全性 ” 这一个选项卡。

  六、系统不能打开注册表关键字(8007000e)

  Microsoft OLE DB Provider for ODBC Drivers 错误 '8007000e'

  常见错误 不能打开注册表关键字 'Temporary (volatile) Jet DSN for process 0x11b4 Thread 0x1a4c DBC 0x9d34354 Jet'。

  产生错误可能原因:

  1.打开数据库时写法不对,标准的ACCESS数据库调用写法:(如果无法记清如何写,可利用DW的帮助)

  "driver={Microsoft Access Driver (*.mdb)};dbq=" & server.mappath("db.MDB")

  2. 正在上传数据库文件。

  总之在用DW制作ASP网站时使用数据库比较容易出现错误,错误出现时一定要看清错误的类型,多加思考多请教一定会得到解决。



上一页 1 2 3下一页
收藏此页到网摘/书签:
所有评论

评论列表

用户名: 新注册) 密码: 匿名评论