当前位置: 代码迷 >> 综合 >> 日常任务-07-技术-12.Mybatis中“CDATA”的用法
  详细解决方案

日常任务-07-技术-12.Mybatis中“CDATA”的用法

热度:90   发布时间:2023-12-16 10:51:11.0

被<![CDATA[]]>这个标记所包含的内容将表示为纯文本,比如<![CDATA[<]]>表示文本内容“<”。
  此标记用于xml文档中,我们先来看看使用转义符的情况。我们知道,在xml中,”<”、”>”、”&”等字符是不能直接存入的,否则xml语法检查时会报错,如果想在xml中使用这些符号,必须将其转义为实体,如”<”、”>”、”&”,这样才能保存进xml文档。

不管怎么样,转义前的字符也好,转义后的字符也好,都会被xml解析器解析,为了方便起见,使用<![CDATA[]]>来包含不被xml解析器解析的内容。但要注意的是:
  (1) 此部分不能再包含”]]>”;
  (2) 不允许嵌套使用;
  (3)”]]>”这部分不能包含空格或者换行。
  最后,说说<![CDATA[]]>和xml转移字符的关系,它们两个看起来是不是感觉功能重复了?
  是的,它们的功能就是一样的,只是应用场景和需求有些不同:
  (1)<![CDATA[]]>不能适用所有情况,转义字符可以;
  (2) 对于短字符串<![CDATA[]]>写起来啰嗦,对于长字符串转义字符写起来可读性差;
  (3) <![CDATA[]]>表示xml解析器忽略解析,所以更快。

mybatis中<![CDATA[ ]]> 的作用:

   在使用mybatis 时我们sql是写在xml 映射文件中,如果写的sql中有一些特殊的字符的话,在解析xml文件的时候会被转义,但我们不希望他被转义,所以我们要使用<![CDATA[ ]]>来解决。
 

案例:

 <if test="beginTime != '' and beginTime != null"><![CDATA[ and DATE_FORMAT(c.insert_time, '%Y-%m-%d') >= #{beginTime} ]]></if><if test="endTime != '' and endTime != null"><![CDATA[AND  DATE_FORMAT(c.insert_time, '%Y-%m-%d') <= #{endTime}]]></if>

  相关解决方案