Oracle
 sql >> база данни >  >> RDS >> Oracle

Oracle UpdateXML() променя XML структурата?

Мисля, че можете да избегнете проблема, като замените празния текст с временна стойност, актуализирате целия останал текст и след това замените временната стойност с нула.

Не разбирам 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);



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. как да добавите повече от 1000 стойности с клауза NOT IN

  2. if-elseif-else 'условие' в oracle SQL

  3. Как да намерите текущи отворени курсори в Oracle

  4. Сравнете BLOB с други BLOB в базата данни на Oracle

  5. Oracle:Java съхранена процедура, изпращаща JMS съобщение