vb.net – .NET OleDb参数化查询无法按预期工作

前端之家收集整理的这篇文章主要介绍了vb.net – .NET OleDb参数化查询无法按预期工作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试将此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,您需要以相同的顺序添加参数.

原文链接:https://www.f2er.com/vb/255887.html

猜你在找的VB相关文章