oldDbCommand怎样update?

lavalake 2003-01-25 08:35:29
<%@ Page Language="vb" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.OleDb" %>

<html>
<Script Runat=Server>
Sub Page_Load(Sender As Object, e As EventArgs)
Dim cnA As new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Inetpub\wwwroot\commoninfo.mdb")
Dim cmdA as OleDbCommand
Dim strS as string
strS="update 201 set 电话=2993 where 地址='办公室'"
cnA.open()
cmdA=new OledbCommand(strS,cnA)
cmdA.ExecuteNonQuery
cna.close()
end sub
</script>
</html>
...全文
38 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
lavalake 2003-01-25
  • 打赏
  • 举报
回复
我找到了解决的办法,只要我把commoninfo.mdb设置为everyone 完全控制,就可以了。
原来原因在访问WEB的帐号无权修改文件!!
气死我也!!!!!
那么为什么还会出现我打开文件时提示文件为只读的情况呢?
lavalake 2003-01-25
  • 打赏
  • 举报
回复
我发现在我用access打开commoninfo.mdb时,访问上面的文件就会产生如下的错误:不能使用 '';文件已在使用中。
并且,如果执行了错误的aspx页后,再打开commoninfo时,access会提示文件为只读,我查看了access打开文件的方式,是共享。
这里面有什么问题吗?
lavalake 2003-01-25
  • 打赏
  • 举报
回复
“/”应用程序中的服务器错误。
--------------------------------------------------------------------------------

操作必须使用一个可更新的查询。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Data.OleDb.OleDbException: 操作必须使用一个可更新的查询。

源错误:


行 13: cmdA.connection=cnA
行 14: cmdA.commandtext=strS
行 15: cmdA.ExecuteNonQuery()
行 16: cna.close()
行 17: end sub


源文件: c:\inetpub\wwwroot\index.aspx 行: 15

堆栈跟踪:


[OleDbException (0x80004005): 操作必须使用一个可更新的查询。]
System.Data.OleDb.OleDbCommand.ExecuteCommandTextErrorHandling(Int32 hr) +41
System.Data.OleDb.OleDbCommand.ExecuteCommandTextForSingleResult(tagDBPARAMS dbParams, Object& executeResult) +154
System.Data.OleDb.OleDbCommand.ExecuteCommandText(Object& executeResult) +92
System.Data.OleDb.OleDbCommand.ExecuteCommand(CommandBehavior behavior, Object& executeResult) +65
System.Data.OleDb.OleDbCommand.ExecuteReaderInternal(CommandBehavior behavior, String method) +112
System.Data.OleDb.OleDbCommand.ExecuteNonQuery() +54
ASP.index_aspx.Page_Load(Object Sender, EventArgs e) in c:\inetpub\wwwroot\index.aspx:15
System.Web.UI.Control.OnLoad(EventArgs e) +67
System.Web.UI.Control.LoadRecursive() +29
System.Web.UI.Page.ProcessRequestMain() +724


wkb2002 2003-01-25
  • 打赏
  • 举报
回复
把详细的错误帖出来!
lavalake 2003-01-25
  • 打赏
  • 举报
回复
问题不在这里,加引号和不加都一样的结果,您能否在自己的机器上试一试,只需改一样连接字符串和strS。
先谢谢了
wkb2002 2003-01-25
  • 打赏
  • 举报
回复
strS="update 201 set 电话=2993 where 地址='办公室'"
你的程序中的2993没有加引号
lavalake 2003-01-25
  • 打赏
  • 举报
回复
在access数据库中update 201 set 电话='2993' where 地址='办公室'
执行通过,没有问题。
是不是我的.net有什么问题?
wkb2002 2003-01-25
  • 打赏
  • 举报
回复
上面的错误说明你的查询语句有问题,不是OleDbCommand的问题,你可以把
strS里的sql语句放到commoninfo.mdb的数据库sql查询器中执行,你可能会发现错误,比如:update 201 set 电话=2993 where 地址='办公室'的电话是不是数值...
lavalake 2003-01-25
  • 打赏
  • 举报
回复
故障依旧啊,下面是更改后的代码

<%@ Page Language="vb" %>
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.OleDb" %>

<html>
<Script Runat=Server>
Sub Page_Load(Sender As Object, e As EventArgs)
Dim cnA As new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Inetpub\wwwroot\commoninfo.mdb")
Dim cmdA as new OleDbCommand
Dim strS as string
strS="update 201 set 电话=2993 where 地址='办公室'"
cnA.open()
cmdA.connection=cnA
cmdA.commandtext=strS
cmdA.ExecuteNonQuery
cna.close()
end sub
</script>
</html>
windofcity 2003-01-25
  • 打赏
  • 举报
回复
Dim cmdA as new OleDbCommand
Dim strS as string
strS="update 201 set 电话=2993 where 地址='办公室'"
cnA.open()
cmdA.connection=cnA
cmdA.commandtext=strS
cmdA.ExecuteNonQuery
lavalake 2003-01-25
  • 打赏
  • 举报
回复
我的问题:上面的代码不能通过编译,提示“操作必须使用一个可更新的查询。”请问用oldDbCommand怎样实现数据更新?

62,254

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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