oracle plsql: как анализировать XML и вставлять в таблицу

17

Как загрузить вложенный файл xml в таблицу базы данных?

<?xml version="1.0" ?> 
<person>
   <row>
       <name>Tom</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
   <row>
       <name>Jim</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
</person>       

В этом xml имя человека - это имя таблицы, имя - это имя, Tom - его значение. Адрес является подтаблицей, а состояние и город - это две колонки внутри адреса. Я хочу вставить строку person в таблицу person, если она не удалась, не вставляйте в таблицу адресов. Этот xml может быть очень большим. Какое лучшее решение для этого?     

задан Frank 19.10.2012 в 23:26
источник
  • Попробуйте этот форум forum.oracle.com/forums/thread.jspa?messageID=10269899 –  user75ponic 20.10.2012 в 06:03
  • у меня мало разных деревов xml, help help.gif stackoverflow.com/questions/18583872/... –  zrosystem 03.09.2013 в 07:00

4 ответа

23

Вы можете загрузить XML-документ в XMLType, а затем запросить его, например:

DECLARE
  x XMLType := XMLType(
    '<?xml version="1.0" ?> 
<person>
   <row>
       <name>Tom</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
   <row>
       <name>Jim</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
</person>');
BEGIN
  FOR r IN (
    SELECT ExtractValue(Value(p),'/row/name/text()') as name
          ,ExtractValue(Value(p),'/row/Address/State/text()') as state
          ,ExtractValue(Value(p),'/row/Address/City/text()') as city
    FROM   TABLE(XMLSequence(Extract(x,'/person/row'))) p
    ) LOOP
    -- do whatever you want with r.name, r.state, r.city
  END LOOP;
END;
    
ответ дан Jeffrey Kemp 22.10.2012 в 05:24
источник
  • Это может помочь, но одной большой проблемой является то, что я, возможно, не знаю имя тега, входной файл является динамическим xml со всеми именами и именами таблиц –  Frank 22.10.2012 в 19:33
  • Ну, вам нужно знать, что такое теги, иначе как код должен знать, куда вставлять данные? –  Jeffrey Kemp 24.10.2012 в 10:47
  • Я решил эту проблему с помощью dbms_xmldom API. спасибо за помощь –  Frank 24.10.2012 в 21:10
8
select *  
FROM XMLTABLE('/person/row'  
         PASSING   
            xmltype('
                <person>
                   <row>
                       <name>Tom</name>
                       <Address>
                           <State>California</State>
                           <City>Los angeles</City>
                       </Address>
                   </row>
                   <row>
                       <name>Jim</name>
                       <Address>
                           <State>California</State>
                           <City>Los angeles</City>
                       </Address>
                   </row>
                </person>
            ')
         COLUMNS  
            --describe columns and path to them:  
            name  varchar2(20)    PATH './name',  
            state varchar2(20)    PATH './Address/State',  
            city  varchar2(20)    PATH './Address/City'
     ) xmlt  
;  
    
ответ дан daggett 23.05.2014 в 15:53
источник
  • Когда у меня есть несколько тегов адресов внутри <person> <row>, он получает сбой. Что мне следует изменить, чтобы перебрать несколько тегов с тем же именем? Пожалуйста помоги –  Murali 16.03.2016 в 19:57
  • Если вы хотите получить доступ к первому, тогда xpath будет выглядеть так: './Address[1]/City' –  daggett 19.03.2016 в 07:00
6
CREATE OR REPLACE PROCEDURE ADDEMP
    (xml IN CLOB)
AS
BEGIN
    INSERT INTO EMPLOYEE (EMPID,EMPNAME,EMPDETAIL,CREATEDBY,CREATED)
    SELECT 
        ExtractValue(column_value,'/ROOT/EMPID') AS EMPID
       ,ExtractValue(column_value,'/ROOT/EMPNAME') AS EMPNAME
       ,ExtractValue(column_value,'/ROOT/EMPDETAIL') AS EMPDETAIL
       ,ExtractValue(column_value,'/ROOT/CREATEDBY') AS CREATEDBY
       ,ExtractValue(column_value,'/ROOT/CREATEDDATE') AS CREATEDDATE
    FROM   TABLE(XMLSequence( XMLType(xml))) XMLDUMMAY;

    COMMIT;
END;
    
ответ дан Hemant Kumar Bankey 07.08.2013 в 14:38
источник
3

Вам нужно будет написать много кода для обработки сложных XML-файлов с помощью Oracle. Если у вас большие объемы XML, производительность также может быть проблемой. XML-парсеры класса предприятия позволят обрабатывать большие объемы сложных XML-файлов в реляционном формате без написания кода. Это сообщение в блоге показывает, как пакетные XML-файлы с объемной загрузкой в ​​Oracle без написания кода

    
ответ дан Uli Bethke 07.03.2017 в 13:18
источник