在SQL Server XPath中获取以下兄弟

Chr*_*ton 1 sql-server xpath

由于SQL Server不支持follow-sibling轴 - 获取它的最佳方法是什么?假设我有这样的XML,我希望在节点匹配值'dog'后获得第一个'b'节点:

<root>
    <a>cat</a>
    <b>Cats don't like milk</b>
    <a>dog</a>
    <b>Dogs like everything</b>
</root>
Run Code Online (Sandbox Code Playgroud)

Mik*_*son 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]')
Run Code Online (Sandbox Code Playgroud)