VB6中执行SQL的update命令的问题
下面的修改语句执行起来系统没有任何报错,但是数据库的记录就是没有修改过来。请问是什么原因?
hetong = Left(Combo1.Text, 14)
Sql = "update dbo.SM_SALECTRT set CONTRACT_STATUS = 111 where SALECONTRACT_NAME='" & hetong & "'"
Rs.Open Sql, CN, 3, 1
MsgBox "修改成功"
rs.close
[解决办法]
打断点 然后 将 sql 复制到查询分析器重 执行 然后 测试 是否 sql错误
[解决办法]
多半是SQL语句的条件不成立,检查hetong变量的值数据表对应的字段中是否有记录
[解决办法]
Rs.Open返回一个记录集,并不会执行update语句:
dim n as long
hetong = Left(Combo1.Text, 14)
Sql = "update dbo.SM_SALECTRT set CONTRACT_STATUS = 111 where SALECONTRACT_NAME='" & hetong & "'"
'Rs.Open Sql, CN, 3, 1
CN.execute sql,n
MsgBox "修改了"& n & "行"
cn.close
[解决办法]
用 Open 方法执行无记录集返回的 SQL 语句,也能够运行。
但好的编程习惯还是应该用 Execute 方法。
有记录行返回:
Set recordset = connection.Execute (CommandText, RecordsAffected, Options)
无记录行返回:
connection.Execute CommandText, RecordsAffected, Options
Dim RecordsAffected As Long
CN.execute "Update SM_SALECTRT Set CONTRACT_STATUS = 111 Where SALECONTRACT_NAME='" & hetong & "'", RecordsAffected
If RecordsAffected Then
MsgBox "修改了"& RecordsAffected & "条记录
Else
MsgBox "没有符合条件的记录"
End If