vb.net – .NET OleDb参数化查询无法按预期工作
发布时间:2020-12-17 00:03:24 所属栏目:大数据 来源:网络整理
导读:我正在尝试将此Update命令传递给数据库,它完成没有错误,但它没有更新数据库,我不明白为什么? Dim Cmd As OleDbCommand Dim SQL As String Dim objCmd As New OleDbCommand Dim Con = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source="
我正在尝试将此Update命令传递给数据库,它完成没有错误,但它没有更新数据库,我不明白为什么?
Dim Cmd As OleDbCommand Dim SQL As String Dim objCmd As New OleDbCommand Dim Con = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & My.Settings.MasterPath) Dim Item = "08/08/2015" SQL = ("UPDATE [Hol Dates] SET [" & EmployeeList.Text & "]= @Htype WHERE [HDate]=@Hdate") Cmd = New OleDbCommand(SQL,Con) objCmd = New OleDbCommand(SQL,Con) objCmd.Parameters.AddWithValue("@Hdate",item) objCmd.Parameters.AddWithValue("@Htype","None") Con.Open() Dim ans = MsgBox("Do you want to unbook this holiday?",MsgBoxStyle.YesNo) If ans = MsgBoxResult.Yes Then objCmd.ExecuteNonQuery() Else Exit Sub End If Con.Close() Con.Dispose()
您需要反转将参数添加到OleDbCommand对象的顺序. OleDb允许我们为参数指定名称,但它忽略了名称,只关注参数在CommandText中出现的顺序.
因此,由于您的SQL语句引用了Htype,然后是Hdate,您需要以相同的顺序添加参数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |