SpringBoot系列Mybatis之转义符的使用姿势

124 篇文章 16 订阅
11 篇文章 0 订阅

【DB 系列】Mybatis 之转义符的使用姿势

在 mybatis 的 xml 文件中直接写 sql 比较方便简洁,但是需要注意的是,在 xml 文件中,经常会遇到一些需要转义的场景,比如查询 id < xxx的数据,这个小于号就不能直接写在 sql 中,接下来我们将看一下,mybatis 中的有哪些转义符,可以怎么处理转义问题

I.转义

1. 转义符

在 mybatis 的 xml 文件中,我们最常见的转义符为小于号,如查询 id 小于 100 的数据

<select id="xxx">
  select * from `money` where id &lt; #{id}
</select>

注意上面的 sql,小于号实际使用的是 &lt;,不能直接使用 <,比如直接使用小于号,在 idea 中会有如下的错误提示

日常开发中除了上面的小于号之外,另外一个常见的则是 & 与操作符,如果 sql 中有位操作的场景,同样需要转义

<select id="xxx">
  -- select * from `money` where id & 1 = 1 的sql,需要如下转义
  select * from `money` where id &amp; 1 = 1
</select>

在 mybatis 中常见的几个转义字符表映射关系如下表 (mybatis 的转义实际上完全遵循的是 xml 转义规则,主要有下面几个)

符号转义说明
<<小于
>>大于
&&
'单引号
""双引号

2. <![CDATA[ ]]> 写法

通过转义的方式虽然简单,但是有一个问题就是不够直观,在阅读 sql 时,还需要在脑海里反转义一下,这样就不太友好了,好在 xml 提供了 CDATA 的语法,被包裹在它内部的语句,不会被 xml 解析器进行解析

如通过下面的写法来写与操作

<select id="queryBitCondition" resultType="long">
    select id from money where  <![CDATA[ `money` & #{bit} = #{bit} ]]>
</select>

使用这种方式时,需要注意:

  • 不支持嵌套的写法
  • 结尾符 ]]> 注意与起始符配套使用

III. 不能错过的源码和相关知识点

0. 项目

系列博文:

1. 微信公众号: 一灰灰 Blog

尽信书则不如,以上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现 bug 或者有更好的建议,欢迎批评指正,不吝感激

下面一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛

一灰灰blog

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SpringBoot可以与MyBatis集成,以便在应用程序中使用MyBatis进行数据库操作。在引用中提到的参考文章中,可以找到关于如何在Spring Boot项目中使用MyBatis的具体步骤和配置信息。同时,引用中提到了基于SpringBoot框架的复习过程中使用SpringMVC实现老杜的MyBatis课程。此外,在引用中,也提到了在pom文件中的配置,以及application.properties文件中的MyBatis相关配置。 具体而言,可以按照以下步骤来使用SpringBootMyBatis: 1. 添加MyBatisSpringBoot MyBatis Starter依赖到项目的pom.xml文件中。 2. 创建数据库配置文件,如application.properties,设置数据库连接参数。 3. 创建MyBatis的配置文件,如mybatis-config.xml,配置MyBatis的一些全局参数和插件。 4. 创建Mapper接口和Mapper.xml文件,用于定义数据库操作的接口和对应的SQL语句。 5. 在SpringBoot应用程序的主类上添加注解,如@SpringBootApplication,启用SpringBoot和自动配置。 6. 在需要使用数据库操作的地方,注入Mapper接口,通过调用Mapper接口中的方法来实现对数据库的操作。 通过以上步骤的设置和配置,就可以在SpringBoot项目中使用MyBatis进行数据库操作了。同时,还可以使用SpringMVC来实现老杜的MyBatis课程。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Spring BootMybatis使用](https://blog.csdn.net/herry66/article/details/122699454)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot结合MyBatis 【超详细】](https://blog.csdn.net/m0_65563175/article/details/127354442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一灰灰blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值