Как выбрать конкретные значения из XML с помощью Oracle Xquery - PullRequest
2 голосов
/ 06 января 2012

Вот пример XML, из которого я пытаюсь получить некоторые значения:

<ows:Operation name="DescribeFeatureType">
    <ows:Parameter name="outputFormat">
        <ows:Value>text/xml; subtype=gml/3.1.1</ows:Value>
    </ows:Parameter>
</ows:Operation>
<ows:Operation name="GetFeature">
    <ows:Parameter name="resultType">
        <ows:Value>results</ows:Value>
        <ows:Value>hits</ows:Value>
    </ows:Parameter>
    <ows:Parameter name="outputFormat">
        <ows:Value>text/xml; subtype=gml/3.1.1</ows:Value>
        <ows:Value>GML2</ows:Value>
        <ows:Value>GML2-GZIP</ows:Value>
        <ows:Value>SHAPE-ZIP</ows:Value>
        <ows:Value>csv</ows:Value>
        <ows:Value>gml3</ows:Value>
        <ows:Value>gml32</ows:Value>
        <ows:Value>json</ows:Value>
        <ows:Value>text/xml; subtype=gml/2.1.2</ows:Value>
        <ows:Value>text/xml; subtype=gml/3.2</ows:Value>
    </ows:Parameter>
</ows:Operation>

Я хочу получить доступ к значениям параметра «outputFormat» для операции «GetFeature», используя XMLTABLE в Oracle 10GR2.

Я пробовал разные вещи, но они либо не дали мне результатов, либо все. Вот пример, который возвращает все значения.

select t.*
        from xmltable(xmlnamespaces(default 'http://www.opengis.net/wfs'
                                   ,'http://www.opengis.net/gml' as "gml"
                                    ,'http://www.opengis.net/wfs' as "wfs"
                                    ,'http://www.opengis.net/ows' as "ows"
                                    ,'http://www.w3.org/1999/xlink' as "xlink"
                                    ,'http://www.w3.org/2001/XMLSchema-instance' as "xsi"
                                    ,'http://www.opengis.net/ogc' as "ogc")
                      ,'for $d in //ows:Operation/ows:Parameter/ows:Value
                        where //ows:Operation/@name = "GetFeature"
                        and //ows:Parameter/@name="outputFormat"
                        return $d' passing p_xml columns value varchar2(100) path '/') as t

Любая помощь очень ценится.

1 Ответ

2 голосов
/ 06 января 2012

Найден ответ:

select t.*
        from xmltable(xmlnamespaces(default 'http://www.opengis.net/wfs'
                                   ,'http://www.opengis.net/gml' as "gml"
                                    ,'http://www.opengis.net/wfs' as "wfs"
                                    ,'http://www.opengis.net/ows' as "ows"
                                    ,'http://www.w3.org/1999/xlink' as "xlink"
                                    ,'http://www.w3.org/2001/XMLSchema-instance' as "xsi"
                                    ,'http://www.opengis.net/ogc' as "ogc")
                      ,'for $d in //ows:Operation/ows:Parameter/ows:Value
                        where $d/../../@name = "GetFeature"
                        and $d/../@name="outputFormat"
                        return $d' passing p_xml columns value varchar2(100) path '/') as t;

с использованием выражения xpath для доступа к родительским узлам.

...