Oracle UpdateXML () меняет структуру XML? - PullRequest
2 голосов
/ 01 ноября 2011

Когда я звоню UpdateXML(), я обнаруживаю, что пустые узлы преобразуются в сокращенный XML.Есть ли способ предотвратить поведение UpdateXML() таким образом, возможно, флаг или параметр или альтернативное выражение XPath, чтобы сказать ему сохранить первоначальную структуру?*

/* Desired Output, vs. Example 2 */
SELECT UpdateXML(xmlData, '/TEST/VALUE/text()', 'hello') as "Desired Output"
  FROM (SELECT XMLType('<TEST><VALUE></VALUE></TEST>') as xmlData 
          FROM DUAL);

Desired Output
--------------
<TEST><VALUE></VALUE></TEST>

1 Ответ

0 голосов
/ 02 ноября 2011

Я думаю, что вы можете избежать этой проблемы, заменив пустой текст временным значением, обновив весь остальной текст, а затем заменив временное значение пустым.

Я не понимаю XPath, возможно, есть гораздо лучший способ сделать это, но, похоже, это работает:

SELECT
    --#3: Replace the temporary value with null, this keeps the start and end tag
    UpdateXML(
        --#2: Replace everything but the temporary value
        UpdateXML(
            --#1: Replace empty text with a temporary value
            UpdateXML(xmlData, '/TEST/VALUE[not(text())]', '<VALUE>TEMPORARY VALUE</VALUE>')
        ,'/TEST/VALUE[text()!="TEMPORARY VALUE"]/text()', 'hello')
    ,'/TEST/VALUE[text()="TEMPORARY VALUE"]/text()', null) examle
FROM (SELECT XMLType('<TEST><VALUE>hi</VALUE><VALUE>hola</VALUE><VALUE></VALUE></TEST>') as xmlData FROM DUAL);
...