删除SQL更新中WHERE之前的最后一个逗号

问题描述

| 我正在使用\“ SET Column = @param,\”字符串手动构建sql UPDATE语句。我的问题是WHERE之前的这些SET语句的最后一个不应包含逗号,因为这是语法错误。 所以我的代码看起来像这样:
Public Sub Update(byval id as Integer,Optional byval col1 as String = nothing,Optional byval col2 as Integer = -1)

 Dim sqlupdateid As sqlParameter
 Dim sqlupdatecol1 As sqlParameter
 Dim sqlupdatecol2 As sqlParameter

 Using sqlupdate As sqlCommand = _connection.CreateCommand()
    sqlupdate.CommandType = CommandType.Text
    Dim updatedelim As String = \",\"
    Dim setcol1 As String = \"SET Col1 = @col1\"
    Dim setcol2 As String = \"SET Col2 = @col2\"

   sqlupdate.CommandText = \"UPDATE dbo.MyTable\"

    If Not Isnothing(col1) Then
        sqlupdate.CommandText += \" \"
        sqlupdate.CommandText += setcol1
        sqlupdate.CommandText += updatedelim

        sqlupdatecol1 = sqlupdate.CreateParameter()
        sqlupdatecol1.ParameterName = \"@col1\"
        sqlupdatecol1.DbType = sqlDbType.VarCHar
        sqlupdatecol1.Value = col1
        sqlupdate.Parameters.Add(sqlupdatecol1)
    End If
    If Not col2 = -1 Then
        sqlupdate.CommandText += \" \"
        sqlupdate.CommandText += setcol2
        sqlupdate.CommandText += updatedelim

        sqlupdatecol2 = sqlupdate.CreateParameter()
        sqlupdatecol2.ParameterName = \"@col2\"
        sqlupdatecol2.DbType = sqlDbType.Int
        sqlupdatecol2.Value = col2
        sqlupdate.Parameters.Add(sqlupdatecol2)
    End If

    sqlupdate.CommandText += \" WHERE ID = @id\"
    //try to remove the last comma before the WHERE... (doesn\'t work)
    Dim temp As String = sqlupdate.CommandText
    Dim space As Char = \" \"
    Dim list As String() = temp.Split(space)
    Dim last As String = String.Empty
    Dim removed As String = String.Empty
    For Each s As String In list
        If s.Contains(\"WHERE\") Then
            If last.Contains(\",\") Then
                removed = last.TrimEnd(\",\")
            End If
        End If
        last = s
    Next

    Dim cmd As String = list.ToString()
    sqlupdate.CommandText = cmd
    sqlupdateid = sqlupdate.CreateParameter()
    sqlupdateid.ParameterName = \"@id\"
    sqlupdateid.DbType = sqlDbType.Int
    sqlupdateid.Value = id
    sqlupdate.Parameters.Add(sqlupdateid)

    sqlupdate.ExecuteNonQuery()
  End Using
End Sub
有人可以建议一种更好的算法来删除sql语句中WHERE之前的最后一个逗号,同时要记住,它前面的SET语句的数量会有所不同吗? 由于我要在每个集合后面添加一个逗号,因为另一个可以跟随也可以不跟随,所以我必须在建立UPDATE之后去查找最后一个逗号并将其删除。 所以它应该看起来像这样:
UPDATE dbo.MyTable SET Col1 = @col1,SET Col2 = @col2 WHERE id = @id
    

解决方法

String Query = Query.Substring(0,Query.Length-1)
    ,当您自由使用
+=
运算符时,我建议您完全更改此方法。您可以将字符串放在列表中,然后将它们连接起来以形成一个逗号分隔的列表:
Public Sub Update(byval id as Integer,Optional byval col1 as String = Nothing,Optional byval col2 as Integer = -1)

  Dim sqlupdateid As SqlParameter
  Dim sqlupdatecol1 As SqlParameter
  Dim sqlupdatecol2 As SqlParameter

  Using sqlupdate As SqlCommand = _connection.CreateCommand()
    sqlupdate.CommandType = CommandType.Text

    Dim sets As New List(Of String)

    If Not IsNothing(col1) Then
      sets.Add(\"Col1 = @col1\")
      sqlupdatecol1 = sqlupdate.CreateParameter()
      sqlupdatecol1.ParameterName = \"@col1\"
      sqlupdatecol1.DbType = SqlDbType.VarChar
      sqlupdatecol1.Value = col1
      sqlupdate.Parameters.Add(sqlupdatecol1)
    End If
    If Not col2 = -1 Then
      sets.Add(\"Col2 = @col2\")
      sqlupdatecol2 = sqlupdate.CreateParameter()
      sqlupdatecol2.ParameterName = \"@col2\"
      sqlupdatecol2.DbType = SqlDbType.Int
      sqlupdatecol2.Value = col2
      sqlupdate.Parameters.Add(sqlupdatecol2)
    End If

    sqlupdate.CommandText = _
      \"UPDATE dbo.MyTable SET \" +_
      String.Join(\",\",sets.ToArray()) +_
      \" WHERE ID = @id\"

    sqlupdateid = sqlupdate.CreateParameter()
    sqlupdateid.ParameterName = \"@id\"
    sqlupdateid.DbType = SqlDbType.Int
    sqlupdateid.Value = id
    sqlupdate.Parameters.Add(sqlupdateid)

    sqlupdate.ExecuteNonQuery()
  End Using
End Sub
    ,动态创建“ 5”查询(不带“ 6”子句)。 然后做ѭ7。 最后附加到q
WHERE
子句。     ,不用花哨的字符串操作,您可以执行此操作
UPDATE dbo.MyTable
SET Col1 = @col1,Col2 = @col2,@id = @id
WHERE id = @id
也就是说,附加
@id = @id
您可以在UPDATE中为变量赋值
...
      | @variable = expression
      | @variable = column = expression
      ....
      | @variable { += | -= | *= | /= | %= | &= | ^= | |= } expression
      | @variable = column { += | -= | *= | /= | %= | &= | ^= | |= } expression
当然也可以表达
@variable