【问题标题】:Oracle: How to extract XML data from attributes in tableOracle:如何从表中的属性中提取 XML 数据
【发布时间】:2019-08-05 15:25:26
【问题描述】:

我有一个带有 XmlType 属性的表格,如下所示

<data>
    <subdata name='FIRST'>AAA</subdata>
    <subdata name='SECOND'>BBB</subdata>
    <subdata name='THIRD'>CCC</subdata>
    ...
</data>

我想提取XML得到如下结果:

----------------------------
| FIRST   | SECOND  | THIRD
|---------|---------|-------
| AAA     | BBB     | CCC
----------------------------

有什么想法吗? 我想补充一点,我知道结果表的结构,但每个元素都可以在 xml 中选择。

<data>
        <subdata name='FIRST'>AAA</subdata>
        <subdata name='SECOND'>BBB</subdata>
        <subdata name='THIRD'>CCC</subdata>
        ...
    </data>
<data>

        <subdata name='SECOND'>EEE</subdata>
        <subdata name='THIRD'>DDD</subdata>
        ...
    </data>

| FIRST   | SECOND  | THIRD
|---------|---------|-------
| AAA     | BBB     | CCC
|              | EEE      | DDD
----------------------------

【问题讨论】:

    标签: xml-parsing oracle12c xmltype xmltable


    【解决方案1】:

    你可以尝试这样做:

    SELECT 
      ExtractValue(Value(p),'/data/subdata[@name="FIRST"]/text()') as name1
    , ExtractValue(Value(p),'/data/subdata[@name="SECOND"]/text()') as name2
    , ExtractValue(Value(p),'/data/subdata[@name="THIRD"]/text()') as name3
    FROM TABLE(XMLSequence(Extract(xmltype('<doc><data><subdata name="FIRST">AAA</subdata><subdata name="SECOND">BBB</subdata><subdata name="THIRD">CCC</subdata></data><data><subdata name="SECOND">EEE</subdata><subdata name="THIRD">DDD</subdata></data></doc>')
          ,'/doc/data'))) p
    
    

    【讨论】:

      猜你喜欢
      • 2016-05-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-05-05
      • 1970-01-01
      • 1970-01-01
      • 2021-03-27
      相关资源
      最近更新 更多