mybatis配置返回boolean类型

先大概说明一下ResultMapResultType的使用场景

  • ResultMap适用于复杂的查询,可以处理多表关联查询、嵌套查询等情况。通过ResultMap,可以更精确地控制查询结果的映射。
  • ResultType适用于简单的查询,而ResultMap适用于复杂的查询。具体使用哪种方式,取决于查询结果的结构和映射需求。

ResultType的值一般采用别名方式:

  • 对于引用数据类型,都是将大写字母转小写,如java.lang.String对应的别名是'string';HashMap对应的别名是'hashmap'
  • 对于基本数据类型,考虑到重复的问题,会在其前面加上_,如int对应的别名是'_int';boolean对应的别名是'_boolean'

在业务开发中,我们可能会遇到这样的需求:在对数据进行操作时,先判断有没有对应的记录,如果有,再进行操作。实现的方式有多种,现针对mybatis的实现进行说明。

Mapper方法

java 复制代码
//是否存在当前状态的订单
boolean existsOrder(@Param("orderStatus") String orderStatus);
xml 复制代码
<select id="existsOrder" parameterType="String" resultType="_boolean">
    select count(`id`)
    from `order`
    where `status` = #{orderStatus}
</select>

Mybatis是根据查询到的记录数进行转换的(1表示为true,0表示为false) 。然而,如果查询到多条记录(大于1),则返回的布尔值为false。

这个和mysql的版本有关系,故为了兼容版本我们可以考虑做如下sql改造使用 limit 1 限制只查一条数据。

xml 复制代码
<select id="existsOrder" parameterType="String" resultType="_boolean">
    select count(1)
     from (select 1
    	   from `order`
           where `status` = #{orderStatus} limit 1) t_
</select>

测试方法:

java 复制代码
@Test
public void testExistsOrder(){
	//如果查询到则返回true;否则返回false
	boolean existsUnfishedOrder = orderMapper.existsOrder("unfinished");
	if (existsUnfishedOrder){
		// 业务逻辑
	} else {
		throw new Exception("不存在符合条件的订单!");
	}
}
相关推荐
MaCa .BaKa12 小时前
44-校园二手交易系统(小程序)
java·spring boot·mysql·小程序·maven·intellij-idea·mybatis
java1234_小锋13 小时前
Java高频面试题:MyBatis如何实现动态数据源切换?
java·开发语言·mybatis
小旭952717 小时前
SpringBoot + 七牛云 + Quartz:图片存储与定时清理
java·spring boot·后端·mybatis
夕除20 小时前
MVN--06
数据库·sql·mybatis
计算机学姐2 天前
基于SpringBoot的高校餐饮档口管理系统
java·vue.js·spring boot·后端·spring·intellij-idea·mybatis
身如柳絮随风扬2 天前
MyBatis-Plus与PageHelper分页方案对比
mybatis
罗山仔2 天前
【Vertx构建异步响应式reactive mybatis,mybatis-vertx-adaptor】
mybatis·orm·异步·reactive·响应式·webflux·vertx
java1234_小锋2 天前
Java高频面试题:如何编写一个MyBatis插件?
java·开发语言·mybatis
fe7tQnVan2 天前
MyBatis-动态sql与高级映射
数据库·sql·mybatis
qq12_8115175153 天前
Java Web 影城会员管理系统系统源码-SpringBoot2+Vue3+MyBatis-Plus+MySQL8.0【含文档】
java·前端·mybatis