Я вручную создаю инструкцию SQL UPDATE из строк "SET Column = @param,".У меня проблема в том, что последний из этих операторов SET перед WHERE не должен содержать запятую, так как это синтаксическая ошибка.
Так что мой код выглядит так:
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
Кто-нибудь может предложить лучший алгоритм удаления последней запятой перед WHERE в операторе SQL, имея в виду, что число операторов SET до этого будет меняться?
Поскольку я добавляю запятую после каждогоустановить, так как другой может следовать или не следовать, поэтому я должен после создания ОБНОВЛЕНИЯ, найти последнюю запятую и удалить ее.
Так что это должно выглядеть так:
UPDATE dbo.MyTable SET Col1 = @col1, SET Col2 = @col2 WHERE id = @id