繁体   English   中英

如何使用XQuery-sql在XML中查找祖先

[英]how to find ancestors in XML using XQuery-sql

我正在使用一些xml列,并使用XQuery查找特定子项(子E)的第一个最近的祖先(B),但是会发生以下错误:

消息9335,级别16,状态1,行16 XQuery [query()]:不支持XQuery语法'ancestor'。

祖先和后代的深度级别不是静态的,我希望结果是我试过的“B2”

    DECLARE @x xml
SET @x = CAST(
'<A>
    <B name="B1">
        <C>
            <B id="1" name="B2">
                <D id="1.1" name="D1">
                    <E id="1" />
                    <E id="2" />
                </D>
            </B>
        </C>
    </B>    
</A>' AS xml)

SELECT @x.query('data(//E/ancestor::B[1]/@name)')

你能帮我吗?

您可以尝试使用不同的方法来避免必须调用ancestor轴,例如:

SELECT @x.query('data(//B[.//E][not(.//B)]/@name)')

关于正在使用的谓词的简要说明:

  • [.//E] :确保目标B元素具有后代元素E
  • [not(.//B)] :确保目标B元素没有后代元素B ,换句话说,目标B元素必须是具有后代E的最内层B元素
DECLARE @h int

DECLARE @x xml
SET @x = CAST(
'<A>
    <B name="B1">
        <C>
            <B id="1" name="B2">
                <D id="1.1" name="D1">
                    <E id="1" />
                    <E id="2" />
                </D>
            </B>
        </C>
    </B>    
</A>' AS xml)

EXEC sp_xml_preparedocument @h OUTPUT, @x

SELECT eId, bName
FROM OPENXML(@h, '//E', 2)
WITH 
(
    eId varchar(5) '@id', 
    bName varchar(5) 'ancestor::B[1]/@name')

EXEC sp_xml_removedocument @h

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM