Oracle SQL XML выписка - PullRequest
       0

Oracle SQL XML выписка

0 голосов
/ 09 июля 2020

Я пытаюсь извлечь данные из XML, используя oracle SQL, но возвращает нулевое значение. Это мой XML:

<?xml version="1.0"?>
<fileinfo>
<header>
<system>ABC</system>
<fileID>1</fileID>
</header>
<data>
<Linearcurve>
<fieldID>123</fieldID>
<fieldName>EFG</fieldName>
<Curve>
<curveID>1</curveID>
<xvalue>23</xvalue>
<lastUpdated>
<month>01</month>
<day>01</day>
<year>2001</year>
<hour>01</hour>
<minute>01</minute>
<second>01</second>
</lastUpdated>
<value>
<valueID>1</valueID>
<lowerCurve>
<points>
<point1>0.22</point1>
</points>
</lowerCurve>
</value>
<value>
<valueID>2</valueID>
<lowerCurve>
<points>
<point1>-0.22</point1>
</points>
</lowerCurve>
</value>
</Curve>
</Linearcurve>

Я пытаюсь извлечь значения valueID и point1 , но вернуть пустое значение Вот мой скрипт

WITH XML_CTE as (select xml.* from file1 u, XMLTABLE('//Linearcurve/Curve'
    PASSING XMLTYPE(u.xmlfile)
    COLUMNS
        curveID PATH './../fieldID'
             ,curveID PATH 'curveID'
        ,valueID PATH '//Curve/value/valueID'
        ,point1 PATH '//value/lowerCurve/points/point1' 
    ) xml
)
select * from xml_cte

В идеале возврат должен включать valueID 1 point1 0.22 valueID 2 poing1 -0.22

1 Ответ

1 голос
/ 09 июля 2020

Вы можете сделать это с помощью:

select x.*
from file1 f1
cross join xmltable (
  '//Linearcurve/Curve/value'
  passing xmltype(f1.xmlfile)
  columns
    fieldID PATH './../../fieldID'
   ,curveID PATH './../curveID'
   ,valueID PATH 'valueID'
   ,point1 PATH 'lowerCurve/points/point1' 
) x;

FIELDID | CURVEID | VALUEID | POINT1
:------ | :------ | :------ | :-----
123     | 1       | 1       | 0.22  
123     | 1       | 2       | -0.22 

db <> fiddle

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...