Oracle
 sql >> Datenbank >  >> RDS >> Oracle

XML-Knotenwert ändern – UpdateXML-Äquivalent für Oracle 12c

Die Oracle-Dokumentation empfehlt die Verwendung von XQuery zum Aktualisieren von XML . Probieren Sie es also zuerst aus.

Erstens ist es mit dem alten Ansatz mit Funktion möglich. XQuery unten kann anstelle des Aufrufs von XmlUpdate verwendet werden :

    XMLQuery(
      ' 
        declare function local:copy-replace($element as element()) {  
          if ($element/self::node_2) then <node_2/>
          else if ($element/self::node_3) then <node_3/>
          else if ($element/self::node_4) then <node_4/>
          else element {node-name($element)}  
                       {$element/@*, 
                        for $child in $element/node()  
                        return if ($child instance of element())  
                               then local:copy-replace($child)  
                               else $child  
                       }  
        };  
        local:copy-replace($p/*)
      '
      passing x as "p" returning content
    ) as xcol_2  

Eine andere, kürzere und intuitivere Variante:

    XMLQuery(
      '              
        copy $p2 := $p
        modify(
          replace value of node $p2/node_root/node_2 with "",
          replace value of node $p2/node_root/node_3 with "",
          replace value of node $p2/node_root/node_4 with ""
        )
        return $p2
      '
      passing x as "p" returning content
    ) as xcol_3

Außerdem ist es möglich, nur dann einen modifizierten XML-Wert zurückzugeben, wenn die Bedingung nicht erfüllt ist:

WITH xtbl AS
     (SELECT 1 AS xtbl_id,
             xmltype ('<node_root>
                    <node_1>12</node_1>
                    <node_2>233</node_2>
                    <node_3>223</node_3>
                    <node_4>234</node_4>
               </node_root>') AS x
        FROM Dual
      UNION ALL
      SELECT 2, xmltype ('<node_root>
                    <node_1></node_1>
                    <node_2>233</node_2>
                    <node_3>223</node_3>
                    <node_4>234</node_4>
               </node_root>')
        FROM Dual)
SELECT xtbl_id,
   x,
    XMLQuery(
      '   
        for $test in $p/*
        return 
          if( empty($p/node_root/node_1/text()) )             
            then $p
            else (
             copy $p2 := $p
              modify(
                replace value of node $p2/node_root/node_2 with "",
                replace value of node $p2/node_root/node_3 with "",
                replace value of node $p2/node_root/node_4 with ""
              )
              return $p2
           )   
      '
      passing x as "p" returning content
    ) as xcol_4
FROM xtbl

Es gibt also viele Varianten, um Operationen auf XML-Werten durchzuführen, aber dies erfordert tiefere Kenntnisse von XQuery und XPath als eine relativ einfache XmlUpdate-Funktion ...