MyBatis中Mapper.xml文件中的转义字符
一、XML转义字符
XML只有5个转义符:
转义符 | 表达式 | 说明 |
---|---|---|
< |
< | 小于号 |
> |
> | 大于号 |
& |
& | 和 |
' |
’ | 单引号 |
" |
" | 双引号 |
值得注意的是:
- 转义序列字符之间不能有空格;
- 转义序列必须以”;”结束;
- 单独出现的”&”不会被认为是转义的开始;
- 区分大小写。
但是严格来说,在XML中只有”<”和”&”是非法的,其它三个都是可以合法存在的,但是,把它们都进行转义是一个好的习惯。
用转义字符进行替换:
例如,查询年龄<=30 且 >=18的用户 :
SELECT * FROM user WHERE age <= 30 AND age >= 18
二、<![CDATA[ ]]>
符号
被<![CDATA[]]>
这个标记所包含的内容将表示为纯文本,比如<![CDATA[<]]>表示文本内容“<”。
不管怎么样,转义前的字符也好,转义后的字符也好,都会被xml解析器解析,为了方便起见,使用<![CDATA[]]>
来包含不被xml解析器解析的内容。
但要注意的是:
- 此部分不能再包含”]]>”;
- 不允许嵌套使用;
- "]]>"这部分不能包含空格或者换行。
所以上面的SQL可以写成这个:
<![CDATA[ SELECT * FROM user WHERE age <= 30 AND age >= 18 ]]>
最后,说说<![CDATA[]]>
和xml转移字符的关系,它们两个看起来是不是感觉功能重复了?
是的,它们的功能就是一样的,只是应用场景和需求有些不同:
<![CDATA[]]>
不能适用所有情况,转义字符可以;- 对于短字符串
<![CDATA[]]>
写起来啰嗦,对于长字符串转义字符写起来可读性差; <![CDATA[]]>
表示xml解析器忽略解析,所以更快。