2015-04-23 77 views
3

我在插入xmltype到pl/sql中的指定位置的另一個xmltype時遇到問題。將xmltype插入到指定位置的xmltype中[PL/SQL]

第一個變量v_xml的形式爲:

<ord> 
    <head> 
    <ord_code>123</ord_code> 
    <ord_date>01-01-2015</ord_date> 
    </head> 
</ord> 

而第二v_xml2:

<pos> 
    <pos_code>456</pos_code> 
    <pos_desc>description</pos_desc> 
</pos> 

我的目的是得到這樣的:

<ord> 
    <head> 
    <ord_code>123</ord_code> 
    <ord_date>01-01-2015</ord_date> 
    </head> 
    <!-- put the second variable in this place - after closing <head> tag --> 
    <pos> 
    <pos_code>456</pos_code> 
    <pos_desc>description</pos_desc> 
    </pos> 
</ord> 

我768,16做些什麼我的代碼?

declare 
    v_xml xmltype; 
    v_xml2 xmltype; 
begin 
    -- some code 
    -- some code 
    -- v_xml and v_xml2 has the form as I define above 
end; 

有人能幫我解決這個問題嗎?據我所知有功能,如insertchildxml,appendchildxml或類似這樣的... 我發現純SQL的幾個解決方案,但我不知道如何在PL/SQL中移動它。

謝謝!

回答

2

您可以用提到appendChildXML,喜歡這裏:

declare 
    v_xml xmltype := xmltype('<ord> 
           <head> 
           <ord_code>123</ord_code> 
           <ord_date>01-01-2015</ord_date> 
           </head> 
          </ord>'); 
    v_xml2 xmltype:= xmltype('<pos> 
           <pos_code>456</pos_code> 
           <pos_desc>description</pos_desc> 
          </pos>'); 
    v_output xmltype; 
begin 
    select appendChildXML(v_xml, 'ord', v_xml2) 
    into v_output from dual; 

    -- output result 
    dbms_output.put_line(substr(v_output.getclobval(), 1, 1000)); 
end; 

輸出:

<ord> 
    <head> 
    <ord_code>123</ord_code> 
    <ord_date>01-01-2015</ord_date> 
    </head> 
    <pos> 
    <pos_code>456</pos_code> 
    <pos_desc>description</pos_desc> 
    </pos> 
</ord> 
+0

謝謝你的時間,它的工作原理! :) – llepec

2

appendChildXML 12.1

因此,這裏已被棄用是使用XMLQuery

DECLARE 

    l_head_xml XMLTYPE := XMLTYPE.CREATEXML('<ord> 
               <head> 
                <ord_code>123</ord_code> 
                <ord_date>01-01-2015</ord_date> 
               </head> 
               </ord>'); 

    l_pos_xml XMLTYPE := XMLTYPE.CREATEXML('<pos> 
               <pos_code>456</pos_code> 
               <pos_desc>description</pos_desc> 
              </pos>'); 

    l_complete_xml XMLTYPE; 

BEGIN 

    SELECT XMLQUERY('for $i in $h/ord/head 
        return <ord> 
          {$i} 
          {for $j in $p/pos 
          return $j}         
          </ord>'                   
        PASSING l_head_xml AS "h", 
          l_pos_xml AS "p" 
        RETURNING CONTENT) 
    INTO l_complete_xml 
    FROM dual; 

    dbms_output.put_line(l_complete_xml.getstringval()); 

END; 
的解決方案
+0

伊恩 - 如果有屬性,你能解釋你如何還他們? –