XML转义--SQL函数
Posted samrv
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了XML转义--SQL函数相关的知识,希望对你有一定的参考价值。
XML BI Publisher 做发票,
物料型号中有 XML 关键字符,因此需要转义
------------------------------------------------------- -- PLSQL -- 傳入字串,將特殊符號轉成符合XML格式 ------------------------------------------------------- FUNCTION REPLACE_FOR_XML(P_STR IN VARCHAR2) RETURN VARCHAR2 is v_str varchar2(2000); BEGIN -- 單引號 select replace(P_STR,chr(39),chr(38)||‘apos;‘) into v_str from dual; -- 2019/6/6 雙引號 select replace(v_str,CHR(34),chr(38)||‘quot;‘) into v_str from dual; -- & 連接符 select replace(v_str,chr(38),chr(38)||‘amp;‘) into v_str from dual; -- 小於號 select replace(v_str,‘<‘,chr(38)||‘lt;‘) into v_str from dual; -- 大於號 select replace(v_str,‘>‘,chr(38)||‘gt;‘) into v_str from dual; RETURN (v_str); END;
实际还是不能展出目标结果。因为 单引号及双引号转义后 字符串 分别是 “'” 和 “"”, 在第三个转义,则将“&”连接符再次转义为
"&"
故 必须 要将 “&”连接字符的转义放在第一个位置。
正确顺序如下代码:
------------------------------------------------------- -- 傳入字串,將特殊符號轉成符合XML格式 ------------------------------------------------------- FUNCTION REPLACE_FOR_XML(P_STR IN VARCHAR2) RETURN VARCHAR2 is v_str varchar2(2000); BEGIN -- & 連接符 select replace(v_str,chr(38),chr(38)||‘amp;‘) into v_str from dual; -- 單引號 select replace(P_STR,chr(39),chr(38)||‘apos;‘) into v_str from dual; -- 雙引號 select replace(v_str,CHR(34),chr(38)||‘quot;‘) into v_str from dual; -- 小於號 select replace(v_str,‘<‘,chr(38)||‘lt;‘) into v_str from dual; -- 大於號 select replace(v_str,‘>‘,chr(38)||‘gt;‘) into v_str from dual; RETURN (v_str); END;
以上是关于XML转义--SQL函数的主要内容,如果未能解决你的问题,请参考以下文章
使用 sqlite 的 FTS 片段函数处理 html 转义