Получить список элементов и их значений из нетипизированного фрагмента XML в T-SQL - PullRequest
1 голос
/ 27 апреля 2010

Похоже на вопрос: Как получить список имен элементов из значения XML в SQL Server

Как бы я также получил значения для списка элементов.

Например:

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

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

Извините за путаницу, я не знал, как сделать форматирование. Мне просто нужно имя элемента и значение, и мне нет дела до иерархии.

Спасибо

1 Ответ

4 голосов
/ 27 апреля 2010
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)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...