从T-SQL中的非类型化xml片段获取元素及其值的列表

时间:2010-04-27 17:40:44

标签: sql-server xml tsql

类似问题: How can I get a list of element names from an XML value in SQL Server

我如何获取元素列表的值。

例如:

<Root>
<A>a1</A>
<B>b1</B>
<C>c1</C>
</Root>

Would return
Element   |  Value
A         |    a1
B         |    b1
C         |    c1

很抱歉这个混乱,我不知道怎么做格式化。我只想要元素名称和值,而不关心层次结构。

谢谢,

1 个答案:

答案 0 :(得分:4)

declare @xml xml
set @xml = '<Root><A>a1</A><B>b1</B><C>c1</C><D><E>e1</E></D><F>f1<G>g1</G></F></Root>'

select
    element.value('fn:local-name(.)', 'varchar(max)') as Element,
    element.value('text()[1]', 'varchar(max)') as Value
from @xml.nodes('/*//*') as nodes(element)

输出:

Element  Value
-------- ----------
A        a1
B        b1
C        c1
D        NULL
E        e1
F        f1
G        g1

(7 row(s) affected)