T-SQL XQuery,用于为每个嵌套元素的每个匹配XML值返回结果行

时间:2015-12-08 14:53:08

标签: sql sql-server xml tsql xquery

给定表y中的XML数据类型列x,其值为:

<a>
<b>
<c>1</c>
<c>2</c>
<c>3</c>
</b>
</a>

如何使用T-SQL XQuery获取结果集,以便每个<c>元素值返回一行? 假设表y也有列z,其中包含x列中<c>元素的数量 - 只是为了让我们有一个额外的列返回。

迄今为止我们能想到的最好的是:

select 
z, 
cvalues = x.query('data(a/b/c)')
from y

但是上面会在y中每行返回一行,并且在列cvalues中的<c>元素的值的空格分隔列表中。

我们如何获得结果集,例如:

z cvalues
3 1
3 2
3 3

而不是我们现在得到的:

z cvalues
3 1 2 3 

谢谢!

1 个答案:

答案 0 :(得分:3)

您可以将CROSS APPLYnodes结合使用:

SELECT 
  z, 
  cvalues = s.c.value('.', 'int')
FROM y
CROSS APPLY x.nodes('//c') AS s(c);

LiveDemo

输出:

╔═══╦═════════╗
║ z ║ cvalues ║
╠═══╬═════════╣
║ 3 ║       1 ║
║ 3 ║       2 ║
║ 3 ║       3 ║
╚═══╩═════════╝

请记住:

//c匹配所有c xml元素,无论它在层次结构中的位置

/a/b/c将匹配嵌套在ca

中的b xml元素