谈一谈 mybatis中<![CDATA[]]>的作用

本文介绍了在MyBatis中使用<![CDATA[]]>的原因和作用。当SQL语句包含特殊字符,如&gt;或&lt;,在XML解析时可能被转义,使用<![CDATA[]]>可以防止转义,确保SQL正确执行。示例展示了在动态SQL条件判断中如何使用。此外,作者分享了个人从程序员到架构师的职业历程,并提供了一套完整的Java学习资料以帮助开发者提升技能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

<![CDATA[ ]]> 是什么,这是XML语法。

在CDATA内部的所有内容解析器不会进行转义

它一般放在动态SQL拼接语句中,作为数学运算符如 “>=” 或者 “>” 或者 “<” 或者 “<=” 等的外层

实例如下:

<select id="getTokenStr" resultType="java.lang.String">
    SELECT token FROM `task_token` WHERE token_type = #{tokenType}
    <if test="startTime != null ">
       and start_time <![CDATA[ >= ]]> #{startTime}
    </if>
    <if test="endTime != null ">
        and end_time <![CDATA[ <= ]]> #{endTime}
    </if>
	and last_update_date <![CDATA[>=]] now()
</select>

先自我介绍一下,小编13年毕业于厦门大学,14年在外包公司中软干过,后来去过微软、华为等大厂,20年进入鹅厂担任架构师,直到现在。这一路走来,深知大多数初中级java工程师,想要提升技能,往往需要自己长时间的摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率不仅低效而且还很漫长,很容易就碰到天花板致技术停止不前。 因此我收集整理了一份《java开发全套学习资料》送给大家,里面包含了Spring全家桶,MySQL,中间件Redis、kafka,MQ消息,Zookeeper等java全系列资料,非常适合初中高级各个阶段同行学习,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料,后面抽时间定期更新一些干货文章,如果你喜欢,也可添加下方名片学习交流 (๑๑)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值