以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.com/bbs/index.asp)
--  专家坐堂  (http://foxtable.com/bbs/list.asp?boardid=2)
----  请教:更新数据报错,提示:ExecuteNonQuery 要求已打开且可用的连接。连接的当前状态为已关闭。  (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=87298)

--  作者:bahamute
--  发布时间:2016/7/7 17:37:00
--  请教:更新数据报错,提示:ExecuteNonQuery 要求已打开且可用的连接。连接的当前状态为已关闭。
代码如下:
Dim cmd As new SQLCommand
    cmd.C
    Dim dt As DataTable
    Dim count As Integer
    Dim Filter As String
    If t.Current.DataRow.RowState=DataRowState.Added Then
        cmd.CommandText="Insert I nto {银行账户} (工号,姓名,银行账号,银行类别,人员类别) Values(\'" & r("工号") & "\',\'" & r("姓名") & "\',\'" & r("银行账号") & "\',\'" & r("银行类别") & "\',\'" & r("人员类别") & "\')"
        count=cmd.ExecuteNonQuery
        MessageBox.Show("增加" & count & "条记录完毕!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
    Else
        cmd.CommandText="UPDAT E {银行账户} set 姓名=\'" & r("姓名") & "\'," &  "银行账号=\'" & r("银行账号") & "\'," & "人员类别=\'" & r("人员类别") & "\' where [工号]=\'" & r("工号") & "\'"
        count=cmd.ExecuteNonQuery
        MessageBox.Show("修改" & count & "条记录完毕!","提示",MessageBoxButtons.OK,MessageBoxIcon.Information)
    End If

数据库链接没有问题,加载窗体时能够获取数据,但修改后保存就会报错。
[此贴子已经被作者于2016/7/7 17:39:11编辑过]

--  作者:大红袍
--  发布时间:2016/7/7 17:45:00
--  

 就是单单执行一句插入或更新语句?一句,不应该有此问题。是不是你长时间不操作后台数据库,导致连接关闭了?

 

 


--  作者:bahamute
--  发布时间:2016/7/7 17:50:00
--  
没有长时间不操作,就是刚刚需要修改数据,之后保存就这样了。
能不能显式打开连接?
[此贴子已经被作者于2016/7/7 17:50:48编辑过]

--  作者:大红袍
--  发布时间:2016/7/7 18:05:00
--  

output.show(cmd.CommandText)

 

然后拷贝sql语句在测试窗口运行

 

http://www.foxtable.com/webhelp/scr/1484.htm