Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Usuń pusty tag z xmltype oracle

Użyj DELETEXML i poszukaj XPath //*[not(text())][not(*)] aby znaleźć elementy, które nie zawierają tekstu i dzieci:

Skrzypce SQL

Konfiguracja schematu Oracle 11g R2 :

CREATE TABLE table_name ( xml ) AS
SELECT XMLTYPE( '<MESSAGE>
<LOCATIONS>
  <LOCATION_ID>9999</LOCATION_ID>
  <LOC_TYPE>S</LOC_TYPE>
  <NAME>Test Location</NAME> 
  <PHONE_NUM>08 </PHONE_NUM>
   <LAST_MODIFIED_BY/>
   <LAST_MODIFIED_DATE/>
   <POS_CODE/>
</LOCATIONS>
</MESSAGE>' ) FROM DUAL;

Zapytanie 1 :

SELECT DELETEXML(
         xml,
         '//*[not(text())][not(*)]'
       ).getStringVal()
FROM   table_name

Wyniki :

|                                                                                            DELETEXML(XML,'//*[NOT(TEXT())][NOT(*)]').GETSTRINGVAL() |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| <MESSAGE><LOCATIONS><LOCATION_ID>9999</LOCATION_ID><LOC_TYPE>S</LOC_TYPE><NAME>Test Location</NAME><PHONE_NUM>08 </PHONE_NUM></LOCATIONS></MESSAGE> |


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. TO_CHAR typu Oracle PL/SQL TABLE

  2. Wartość logiczna w OracleDbType

  3. Oracle SQL — oznaczanie rekordów na podstawie daty rekordu w porównaniu z historią

  4. Prawidłowe podejście do inicjalizacji asynchronicznego nasłuchiwania JMS i umożliwienia mu nieskończonego działania

  5. Jak przyspieszyć ładowanie danych z Oracle sql do pandas df