Mybatis - <choose> 标签的用法

用法介绍

choose 标签作用是通过条件判断来拼接 SQL 语句,类似于 Java 中的 switch 语句,从上到下,当有匹配的条件时,跳出 choose 语句;如果所有条件都不成立则执行 otherwise 标签中的内容

语法格式为:

<choose>
	<when test=条件1>
		...
	</when>
	<when test=条件2>
		...
	</when>
	<when test=条件3>
		...
	</when>
	...
	<otherwise>
		...
	</otherwise>
</choose>

使用细节

当有条件成立时,就不会继续执行了。

今天就碰到一个同事写的代码,功能是:年月日三个维度查询报表数据
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

后端使用四个字段来接收前端传的参数,分别是:

  • 日查询为:startDate,endDate
  • 月查询为:ymDate
  • 年查询为:yDate

而这个同事在实现这个功能时,采用了 choose 标签来实现,他的 SQL 语句拼接为:

<choose>
    <when test="query.startDate != null and query.startDate != '' and query.endDate != null and query.endDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y-%m-%d') between #{query.startDate} and #{query.endDate}
    </when>
    <when test="query.ymDate != null and query.ymDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y-%m') = #{query.ymDate}
    </when>
    <when test="query.yDate != null and query.yDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y') = #{query.yDate}
    </when>
</choose>

然后就有测试的同学反馈说,为什么只有按 查询可以查到数据,按 都查不到数据,下面给出三种查询的传参:

{
  "startDate": "2022",
  "endDate": "2022",
  "ydate": "2022",
  "ymDate": "2022-05",
}
{
  "startDate": "2022-05",
  "endDate": "2022-05",
  "ymDate": "2022-05",
}
{
    "startDate": "2022-05-30",
    "endDate": "2022-05-30",
    "ydate": null,
    "ymDate": null,
}

按照他的这种传参方式及 choose 判断方式分析,choose 只会执行第一个条件判断。解决办法为调整 when 条件的判断顺序为:

<choose>
    <when test="query.yDate != null and query.yDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y') = #{query.yDate}
    </when>
    <when test="query.ymDate != null and query.ymDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y-%m') = #{query.ymDate}
    </when>
    <when test="query.startDate != null and query.startDate != '' and query.endDate != null and query.endDate != ''">
        and DATE_FORMAT(treat_start_time,'%Y-%m-%d') between #{query.startDate} and #{query.endDate}
    </when>
</choose>

总结

使用 choose 标签的时候,一定要注意最先需要判断的条件要放在前面,当匹配到某个条件时,就不会判断后面的语句了。

  • 9
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MybatisMybatis Plus是两个在Java开发中常用的持久层框架。Mybatis是一个优秀的持久层框架,它通过XML配置文件或注解的方式实现了数据库的操作,同时提供了强大的SQL映射功能。而Mybatis Plus是在Mybatis的基础上进行二次封装的框架,它简化了Mybatis的使用,提供了更加便捷的CRUD操作方法和更加灵活的查询方式,同时还集成了一些常用的功能模块,如分页、逻辑删除等。 在Spring Boot中整合MybatisMybatis Plus可以通过引入相应的依赖和配置文件来实现。可以参考示例代码中的Spring Boot项目,其中包含了整合MybatisMybatis Plus的配置和示例代码。 在配置文件中,可以通过配置MybatisPlusConfig来配置Mybatis Plus的一些参数和功能,例如分页插件、逻辑删除插件等。同时,需要将Mybatis的XML文件放置在resources目录下的mapper文件夹中,以供Mybatis进行SQL映射。 总之,MybatisMybatis Plus都是非常常用的持久层框架,它们可以帮助开发者简化数据库操作,提高开发效率。在Spring Boot中整合它们可以通过引入依赖和配置文件来实现。希望以上信息对您有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot+Mybatis+Mybatis Plus+Shiro实现一个简单的项目架构](https://download.csdn.net/download/feritylamb/11490995)[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_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [spring boot整合mybatis+mybatis-plus的示例代码](https://download.csdn.net/download/weixin_38506798/12764240)[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_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [spring boot整合mybatis+mybatis-plus](https://blog.csdn.net/aotun7642/article/details/102437856)[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_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值