我有这个:
declare @data varchar = 'UI'
我需要解决这个问题,以便它可以与“IN”语句一起使用。
'UI' => 'U','I'
很难完成这件事。有人愿意帮忙吗?
谢谢!
最佳答案
您可以将临时统计表与 Stuff() 和 XML 结合使用。
示例
declare @data varchar(max) = 'UI'
Select S = Stuff((Select ',' +S
From (
Select S=''''+substring(@data,N,1)+''''
From (Select Top (Len(@data)) N=Row_Number() Over (Order By (Select null)) From master..spt_values ) N
) B1
For XML Path ('')),1,1,'')
返回
'U','I'
如果您愿意接受 UDF,请进行编辑
Select S = Stuff((Select ',''' +RetVal + ''''
From (Select * From [dbo].[udf-Str-Parse-Char](@data)) A
For XML Path ('')),1,1,'')
UDF
CREATE FUNCTION [dbo].[udf-Str-Parse-Char] (@String varchar(max))
Returns Table
As
Return (
with cte1(N) As (Select 1 From (Values(1),(1),(1),(1),(1),(1),(1),(1),(1),(1)) N(N)),
cte2(N) As (Select Top (IsNull(DataLength(@String),0)) Row_Number() over (Order By (Select NULL)) From cte1 a,cte1 b,cte1 c,cte1 d,cte1 e,cte1 f)
Select RetSeq=N
,RetVal=Substring(@String,N,1)
From cte2
)
--Max 1 Million Observations
--Select * from [dbo].[udf-Str-Parse-Char]('this is a string')
关于sql - 如何在 SQL Server 中为字符串中的每个字符添加逗号和单引号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43646712/