Sql 从xmltype oracle中删除空标记
我想尝试从xmltype中删除空标记。我已经从oracle类型生成了以下xml。在集合中,少数元素没有值,因此我使用空标记生成 谁能帮我一下吗 实际产量:Sql 从xmltype oracle中删除空标记,sql,xml,oracle,Sql,Xml,Oracle,我想尝试从xmltype中删除空标记。我已经从oracle类型生成了以下xml。在集合中,少数元素没有值,因此我使用空标记生成 谁能帮我一下吗 实际产量: <MESSAGE> <LOCATIONS> <LOCATION_ID>9999</LOCATION_ID> <LOC_TYPE>S</LOC_TYPE> <NAME>Test Location</NAME> <PHONE_N
<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>
预期产出:
<MESSAGE>
<LOCATIONS>
<LOCATION_ID>9999</LOCATION_ID>
<LOC_TYPE>S</LOC_TYPE>
<NAME>Test Location</NAME>
<PHONE_NUM>08 </PHONE_NUM>
</LOCATIONS>
</MESSAGE>
使用DELETEXML并查找XPath/*[nottext][not*]以查找不包含文本和子元素的元素:
Oracle 11g R2架构设置:
:
这很好,感谢@KaushikNayak的可能重复项不是重复项-您链接的一个正在尝试生成XMLType而不包含空XML标记,而这个XMLType已经存在,包含需要删除的空XML标记。
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;
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> |
SELECT
deletexml(xml_data, '//*[not(text())][not(*)]').getstringval()
FROM
(
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>'
) xml_data
FROM
dual
)