好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

mybatis中sql语句CDATA标签的用法说明

sql语句CDATA标签的用法

CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。

在 XML 元素中,"<" 和 [&] 是非法的;

[<] 会产生错误,因为解析器会把该字符解释为新元素的开始;

[&] 也会产生错误,因为解析器会把该字符解释为字符实体的开始;

在mapper文件中写sql语句时,遇到特殊字符时,如:"<" 等,建议使用 <![CDATA[ sql语句 ]]> 标记,将sql语句包裹住,不被解析器解析;

例如:【伪代码】

?

1

select id from t_article where create_time <![CDATA[ <= ]]> now();

使用CDATA[ ]标签进行范围查询

在项目中使用mybatis时的SQL语句是写在xml映射文件中的,如果想要通过大于小于或者大于等于小于等于查询符合范围的数据,但是若写入的SQL语句有一些类似>,<的特殊字符的话,在解析xml文件的时候会被转义,但这并不是我们所希望的,所以这个时候可以使用<![CDATA[]]>标签来解决。

<![CDATA[ ]]> 是什么,这是XML语法。在CDATA内部的所有内容都会被解析器忽略。

如果文本包含了很多的"<"字符 <=和"&"字符——就象程序代码一样,那么最好把他们都放到CDATA部件中。

实例:

?

1

2

3

4

5

6

7

8

9

10

< select id= "findList" resultType= "FleeceRecord" >

         SELECT * FROM `fleece_record`

         < where >

<if test= "naturalLengthStart != null" >

                 and natural_length<![CDATA[>=]]>#{naturalLengthStart}

             </if>

             <if test= "naturalLengthEnd != null" >

                 and natural_length<![CDATA[<=]]>#{naturalLengthEnd}

             </if>

          </ where >

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

原文链接:https://blog.csdn.net/qq_33732195/article/details/112690032

查看更多关于mybatis中sql语句CDATA标签的用法说明的详细内容...

  阅读:22次