Надеюсь, это не повторяющийся вопрос. Я искал проблему на этом сайте все выше и ниже, но ничего не нашел, поэтому вот мой вопрос ...
Я использую XQuery для анализа XML-документа в наборе результатов SQL-сервера. Из-за некоторых повторяющихся пар имя / значение узла, я получаю дубликаты. Почему я получаю эти дубликаты?
Любая помощь или помощь с благодарностью.
XML:
<root>
<record>
<recordid>1</recordid>
<tests>
<test name="Food" value="Apple" />
<test name="Drink" value="Water" />
</tests>
</record>
<record>
<recordid>2</recordid>
<tests>
<test name="Food" value="Banana" />
<test name="Drink" value="Orange Juice" />
</tests>
<tests>
<test name="Food" value="Steak" />
<test name="Drink" value="Beer" />
</tests>
</record>
</root>
SQL:
DECLARE
@XML XML = '<root><record><recordid>1</recordid><tests><test name="Food" value="Apple" /><test name="Drink" value="Water" /></tests></record><record><recordid>2</recordid><tests><test name="Food" value="Banana" /><test name="Drink" value="Orange Juice" /></tests><tests><test name="Food" value="Steak" /><test name="Drink" value="Beer" /></tests></record></root>'
DECLARE @XMLTable AS TABLE (
MyXML XML
)
INSERT INTO @XMLTable(MyXML)
VALUES(@XML)
SELECT
rec.c.value('recordid[1]', 'INT') AS RecordId,
t.c.value('test[@name="Food"][1]/@value[1]', 'VARCHAR(15)') AS Food,
t.c.value('test[@name="Drink"][1]/@value[1]', 'VARCHAR(15)') AS Drink
FROM @XMLTable AS x
CROSS APPLY MyXML.nodes('/root/record') rec(c)
OUTER APPLY MyXML.nodes('/root/record/tests') t(c)
Результаты:
RecordId Food Drink
----------- --------------- ---------------
1 Apple Water
1 Banana Orange Juice
1 Steak Beer
2 Apple Water
2 Banana Orange Juice
2 Steak Beer
Ожидаемые результаты:
RecordId Food Drink
----------- --------------- ---------------
1 Apple Water
2 Banana Orange Juice
2 Steak Beer