繁体   English   中英

如何使用Oracle XMLTABLE从XML返回列

[英]How to return a column from XML using Oracle XMLTABLE

我在表中存储了一些XML 我需要能够使用此XML并提取某些值。

我已经编写了一些代码尝试返回<ns1:Int32/>标记的值,但是到目前为止,我还无法返回结果。

我在网上找到了几个使用XMLTABLE函数的示例,但是不幸的是,这些示例中有很多都比我使用的XML更简单。

XML格式

<Rule Priority="0" Description="Description 1" Active="True" ReevaluationBehavior="Always" Name="Name 1" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/workflow">
    <Rule.Condition>
        <RuleExpressionCondition Name="{p3:Null}" xmlns:p3="http://schemas.microsoft.com/winfx/2006/xaml">
            <RuleExpressionCondition.Expression>
                <ns0:CodeBinaryOperatorExpression Operator="BooleanAnd" xmlns:ns0="clr-namespace:System.CodeDom;Assembly=System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
                    <ns0:CodeBinaryOperatorExpression.Right>
                        <ns0:CodeBinaryOperatorExpression Operator="GreaterThanOrEqual">
                            <ns0:CodeBinaryOperatorExpression.Right>
                                <ns0:CodePrimitiveExpression>
                                    <ns0:CodePrimitiveExpression.Value>
                                        <ns1:Int32 xmlns:ns1="clr-namespace:System;Assembly=mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">11</ns1:Int32>
                                    </ns0:CodePrimitiveExpression.Value>
                                </ns0:CodePrimitiveExpression>
                            </ns0:CodeBinaryOperatorExpression.Right>
                        </ns0:CodeBinaryOperatorExpression>
                    </ns0:CodeBinaryOperatorExpression.Right>
                </ns0:CodeBinaryOperatorExpression>
            </RuleExpressionCondition.Expression>
        </RuleExpressionCondition>
    </Rule.Condition>
</Rule>

SQL

SELECT Rules2.*
FROM RULES Rules1,
XMLTABLE
(
    XMLNAMESPACES
    (
        'http://schemas.microsoft.com/winfx/2006/xaml' AS "p3",
        'clr-namespace:System;Assembly=mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' AS "ns0",
        'clr-namespace:System;Assembly=mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' AS "ns1",
        DEFAULT 'http://schemas.microsoft.com/winfx/2006/xaml/workflow'
    )
    ,
    '/Rule/RuleExpressionCondition/CodeBinaryOperatorExpression/CodePrimitiveExpression'
    PASSING XMLPARSE(CONTENT Rules1.RULE WELLFORMED)
    COLUMNS "Int" INT PATH 'ns1:Int32'
) 
Rules2
;

任何帮助,我们将不胜感激。

ns0的名称空间定义中的URL错误。 xmltable中的错误路径。 您可以使用简短版本。 或提供完整路径。 /Rule/Rule.Condition/RuleExpressionCondition/RuleExpressionCondition.Expression/ns0:CodeBinaryOperatorExpression/ns0:CodeBinaryOperatorExpression.Right/ns0:CodeBinaryOperatorExpression/ns0:CodeBinaryOperatorExpression.Right/ns0:CodePrimitiveExpression/ns0:CodePrimitiveExpression.Value

SELECT Rules2.*
FROM xmls Rules1,
XMLTABLE
(
    XMLNAMESPACES
    (
        'http://schemas.microsoft.com/winfx/2006/xaml' AS "p3",
        'clr-namespace:System.CodeDom;Assembly=System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' AS "ns0",
        'clr-namespace:System;Assembly=mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' AS "ns1",
        DEFAULT 'http://schemas.microsoft.com/winfx/2006/xaml/workflow'
    )
    ,
    '//ns0:CodePrimitiveExpression.Value'
    PASSING XMLPARSE(CONTENT Rules1.RULE WELLFORMED)
    COLUMNS "Int" INT PATH 'ns1:Int32'
) 
Rules2

我认为问题在于您的搜索表达式是

/Rule/RuleExpressionCondition/CodeBinaryOperatorExpression/CodePrimitiveExpression

该表达式缺少多个节点,对吗?

暂无
暂无

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

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