字符数组转换xml


如何将字符串  [[1,3],[7,10],[25,36],[42,68]] 转为

<s key="0">1,3 </s>
<s key="1">7,10 </s>
<s key="2">25,36 </s>
<s key="3">42,68 </s>

IF OBJECT_ID('tempdb..#temp') IS NOT NULL
DROP TABLE #temp
declare @s varchar(540)
set @s='[[1,3],[7,10],[25,36],[42,68]]'
CREATE TABLE #temp
(
  VALUE VARCHAR(20),
  seq INT IDENTITY(1,1) NOT NULL 
)
SET @s=SUBSTRING(@s,2,LEN(@s)-1)


WHILE CHARINDEX(']',@s) >0 
BEGIN
 INSERT INTO #temp
         ( VALUE )
 VALUES  ( SUBSTRING(@s,2,CHARINDEX(']',@s)-2 ) -- VALUE - varchar(20)
                      )                                           
 SET @s=SUBSTRING(@S,CHARINDEX(']',@s)+2,LEN(@S))                    
END
SET @s=''
SELECT @s=@s+ ' <s key='''+
 CAST(seq-1 AS VARCHAR(10))
 +'''>'+ VALUE + ' </s>' FROM #temp 
SELECT  convert(xml, @S )

谁有更好的解决方法 请写出
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值