ORACLE中![CDATA[]]和转义字符
【摘要】 一、前言在DAO层,与实体类相关的SQL语句通常配置在XML文件中,如下SQL语句配置:<select id="queryUsrnmTypOprorder" parameterClass="java.util.HashMap"resultMap="queryCasprjstfsetListMap"> <![CDATA[ select a.usrnm, a....
一、前言
在DAO层,与实体类相关的SQL语句通常配置在XML文件中,如下SQL语句配置:
<select id="queryUsrnmTypOprorder" parameterClass="java.util.HashMap"
resultMap="queryCasprjstfsetListMap">
<![CDATA[
select
a.usrnm,
a.typ,
a.oprorder
from fset a
inner join casprjstfapr
using (stfaprid)
where casprjstfapr.jugsumid = #jugsumid#
and casprjstfapr.blnorg = #blnorg#
and isvld = '1'
order by a.typ asc, a.oprorder asc
]]>
</select>
被![CDATA[]]
这个标记所包含的内容将表示为纯文本,比如![CDATA[]]
表示文本内容“<
”。
此标记用于xml文档中,我们先来看看使用转义符的情况。我们知道,在xml中,”<”、”>”、”&”等字符是不能直接存入的,否则xml语法检查时会报错,如果想在xml中使用这些符号,必须将其转义为实体,如”<
”、”>
”、”&
”,这样才能保存进xml文档。
在使用程序读取的时候,解析器会自动将这些实体转换回”<”、”>”、”&”。举个例子:
二、注意
- 转义序列字符之间不能有空格;
- 转义序列必须以”
;
”结束; - 单独出现的”
&
”不会被认为是转义的开始; - 区分大小写。
在XML中,需要转义的字符有:
但是严格来说,在XML中只有”<
”和”&
”是非法的,其它三个都是可以合法存在的,但是,把它们都进行转义是一个好的习惯。
不管怎么样,转义前的字符也好,转义后的字符也好,都会被xml解析器解析,为了方便起见,使用![CDATA[]]
来包含不被xml解析器解析的内容。但要注意的是:
- 此部分不能再包含”
]]>
”; - 不允许嵌套使用;
- ”
]]>
”这部分不能包含空格或者换行。
最后,说说![CDATA[]]
和xml转移字符的关系,它们两个看起来是不是感觉功能重复了?
三、应用场景和需求
![CDATA[]]
不能适用所有情况,转义字符可以;- 对于短字符串
![CDATA[]]
写起来啰嗦,对于长字符串转义字符写起来可读性差; ![CDATA[]]
表示xml解析器忽略解析,所以更快。
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)