如何解决删除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。
最后附加到qWHERE
子句。
,不用花哨的字符串操作,您可以执行此操作
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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。