提示错误:操作必须使用一个可更新的查询!!!!!!!!

kkmnv 2006-02-03 08:16:45
Dim myconnection As New OleDbConnection
Dim mycommand As New OleDbCommand
Dim myDataReader As OleDbDataReader
Dim Mysql As String
myconnection = New OleDbConnection("provider=microsoft.jet.oledb.4.0;data source=" + Server.MapPath("database/lyb.mdb"))
Mysql = "Insert INTO liuyan(name,email,phone,title,neirong)VALUES(@name,@email,@phone,@title,@neirong)" ' 要插入的值参数化了 。
mycommand = New OleDbCommand(Mysql, myconnection)

Dim pname As New OleDbParameter("@name", OleDbType.VarChar, 50)
Dim pemail As New OleDbParameter("@email", OleDbType.VarChar, 50)
Dim pphone As New OleDbParameter("@phone", OleDbType.VarChar, 50)
Dim ptitle As New OleDbParameter("@title", OleDbType.VarChar, 50)
Dim pneirong As New OleDbParameter("@title", OleDbType.VarChar, 150)

With mycommand.Parameters
.Add(pname)
.Add(pemail)
.Add(pphone)
.Add(ptitle)
.Add(pneirong)
End With
pname.Value = "ZTEST"
pemail.Value = "Z_Ltd"
pphone.Value = "1223"
ptitle.Value = "1212331"
pneirong.Value = "123321321123"

myconnection.Open()
mycommand.ExecuteNonQuery()
myconnection.Close()
全部代码,提示错误:操作必须使用一个可更新的查询
在线等解
...全文
176 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
kkmnv 2006-02-04
  • 打赏
  • 举报
回复
问题解决了。是文件夹的权限设置问题,大家接分了
孟子E章 2006-02-03
  • 打赏
  • 举报
回复
http://hqt.cnblogs.com/archive/2005/07/22/197800.aspx

检查你的database文件夹的安全性是否允许everyone可修改,检查lyb.mdb文件是否允许everyone可修改,并将只读属性去掉,一般是可以的
zhang_frank 2006-02-03
  • 打赏
  • 举报
回复
Mysql = "Insert INTO liuyan(name,email,phone,title,neirong)VALUES(@name,@email,@phone,@title,@neirong)"values前面加空格
kjq_vb 2006-02-03
  • 打赏
  • 举报
回复
是不是你的语句有问题:
Mysql = "Insert INTO liuyan(name,email,phone,title,neirong)VALUES(@name,@email,@phone,@title,@neirong)"
在values前空格了吗

kkmnv 2006-02-03
  • 打赏
  • 举报
回复
不行啊
写个代码我看一下
ah__fu 2006-02-03
  • 打赏
  • 举报
回复
原因很简单name是ACCESS的关键字,把name修改成[name]试试。
如果还不行,就不要使用参数,直接使用一整条SQL语句来执行
kkmnv 2006-02-03
  • 打赏
  • 举报
回复
数据库没问题啊,我重新建立一个也行啊
supershagua 2006-02-03
  • 打赏
  • 举报
回复
数据库连接的问题,检查你的数据库是不是有问题
kkmnv 2006-02-03
  • 打赏
  • 举报
回复
上面的都不是,问题依旧
kkmnv 2006-02-03
  • 打赏
  • 举报
回复
要怎么做才行啊?
孟子E章 2006-02-03
  • 打赏
  • 举报
回复
或者没有匿名修改的权限
孟子E章 2006-02-03
  • 打赏
  • 举报
回复
一般是你的数据库文件只读造成的
经常使用电脑可能也遇到过了! 突然‘咚’的一声 提示 内存不能为read 这个问题我以前也遇到过不知道怎么解决 现在终于有办法了!呵呵! 我们就看看是什么原因引起的吧,另外附送一个小工具修复见下面附件 总结下大概以下9个原因 1、驱动不稳定,与系统不兼容,这最容易出现内存不能为 Read 或者文件保护(主要原因) 2、系统安装了一个或者多个流氓软件,这出现 IE 或者系统崩溃的机会也比较大,也有可能出现文件保护 3、系统加载的程序或者系统正在运行的程序之前有冲突,尤其是部分杀毒软件监控程序 4、系统本身存在漏洞,导致容易受到网络攻击。 5、病毒问题也是主要导致内存不能为 Read、文件保护、Explorer.exe 错误…… 6、如果在玩游戏时候出现内存不能为 Read,则很大可能是显卡驱动不适合(这里的不适合有不适合该游戏、不适合电脑的显卡)也有可能是 系统版本不够新或者不符合该游戏、显卡驱动 7、部分软件本身自身不足的问题 8、电脑硬件过热,也是导致内存不能为 Read 的原因之一。 9、电脑内存与主板兼容性不好也是导致内存不能为 Read 的致命原因! 以上大概就是目前可以引起系统提示 内存不能为read的原因了 另外软件是针对只是针对部分原因引起的内存不为read所做修复,不是100%有效,大家可以试试看 说下原理: 就是批处理使用 regsvr32命令 将动态链接库文件重新注册 (system32下的所有 .dll 和 .ocx 文件;) 注意:由于修复工具会重新注册 system32下的所有 .dll 和 .ocx 文件 此操作对杀毒软件来说属于敏感操作,所以建议使用修复工具的时候,请禁用杀毒软件,以免部分杀毒误报!jie

16,555

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧