1

由于 SQL Server 不支持跟随兄弟轴 - 获得它的最佳方法是什么?假设我有这样的 XML,我想在匹配值“dog”的节点之后获取第一个“b”节点:

<root>
    <a>cat</a>
    <b>Cats don't like milk</b>
    <a>dog</a>
    <b>Dogs like everything</b>
</root>
4

1 回答 1

8

你可以试试这样的。

declare @X xml = '
<root>
    <a>cat</a>
    <b>Cats don''t like milk</b>
    <a>dog</a>
    <c>not this</c>
    <b>Dogs like everything</b>
    <b>and not this</b>
</root>'

select @X.query('(/root/b[. >> (/root/a[. = "dog"])[1]])[1]')
于 2013-10-08T17:05:32.420 回答