sql >> データベース >  >> RDS >> Oracle

xmltypeoracleから空のタグを削除します

    DELETEXMLを使用する XPath //*[not(text())][not(*)]を探します テキストも子も含まない要素を見つけるには:

    SQLフィドル

    Oracle11gR2スキーマのセットアップ

    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;
    

    クエリ1

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

    結果

    |                                                                                            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. ポリゴンポイントを取得するmysql

    2. 次のコードを使用してPHPを使用してMySQLでデータベースを作成する場合、どこに接続し、どこにデータベースを作成しますか?

    3. PostgresDBサイズコマンド

    4. SQLで連続する時間間隔をグループ化する