.NET OleDb 参数化查询未按预期工作
.NET OleDb parameterized query not working as expected
我正在尝试将此更新命令传递给数据库,它完成正常且没有错误,但它没有更新数据库,我不明白为什么?
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
您需要以相同的顺序添加参数。
我正在尝试将此更新命令传递给数据库,它完成正常且没有错误,但它没有更新数据库,我不明白为什么?
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
您需要以相同的顺序添加参数。