0

我想获取一个 xml 字符串并将其转换为 sql-table 分号分隔

declare @x xml --for example
set @x = '<root><row><a>a1</a><b>b2</b></row><row><a>aa1</a><b>bb2</b></row></root>'
SELECT T.c.query('.').query('for $i in row/*/text() return concat($i,";")').value('.', 'nvarchar(max)') AS result  
FROM   @x.nodes('root/row') T(c)  

结果:

a1; b2;
aa1; bb2;

我想要的结果:(没有空格)

a1;b2;
aa1;bb2;

>> 奖励:删除最后一个分号

a1;b2
aa1;bb2

谢谢你!

4

3 回答 3

1

这可以更容易地完成:

DECLARE @xml XML='<root>
  <row>
    <a>a1</a>
    <b>b2</b>
  </row>
  <row>
    <a>aa1</a>
    <b>bb2</b>
  </row>
</root>';

SELECT (
      STUFF(
      (
          SELECT ';' + v.value('.','nvarchar(max)')
          FROM r.nodes('*') AS B(v)
          FOR XML PATH('')
      ),1,1,'')
      )
FROM @xml.nodes('/root/row') AS A(r)
于 2016-08-09T18:39:57.863 回答
1

REPLACE,REVERSE和的组合STUFF是我能够实现这一目标的方式:

declare @x xml --for example
set @x = '<root><row><a>a1</a><b>b2</b></row><row><a>aa1</a><b>bb2</b></row></root>'
SELECT reverse(stuff(reverse(replace(T.c.query('.').query('for $i in row/*/text() return concat($i,";")').value('.', 'nvarchar(max)'), ' ', '')), 1, 1, '')) AS result  
FROM   @x.nodes('root/row') T(c) 

可能有更好的方法来消除空格,因为这也会替换 XML 节点值中的任何空格。

于 2016-08-09T14:06:10.793 回答
0
declare @x xml --for example
set @x = '<root><row><a>a1</a><b>b2</b></row><row><a>aa1</a><b>bb2</b></row></root>'
SELECT reverse(stuff(reverse(replace(T.c.query('.').query('for $i in row/*/text() return concat($i,";")').value('.', 'nvarchar(max)'), '; ', ';')), 1, 1, '')) AS result  
FROM   @x.nodes('root/row') T(c) 
于 2016-08-09T14:39:31.957 回答