类似问题: 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
很抱歉这个混乱,我不知道怎么做格式化。我只想要元素名称和值,而不关心层次结构。
谢谢,
答案 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)