关于mybatis遇到Integer类型的参数时动态sql需要注意条件
mybatis Integer类型参数动态sql注意条件
例如以下拼接的动态sql
<if test="work_status !=null and work_status !='' ">
and T.status=#{work_status,jdbcType=INTEGER}
</if>当work_status为0时,Mybatis会将0解析为了空字符串‘’,这样if判断就为false,如果想正确添加and后的查询条件,应该改成
<if test="work_status !=null ">
and T.status=#{work_status,jdbcType=INTEGER}
</if>mybatis的坑——Integer类型参数解析问题
有时候我们使用实体类传递参数时
有些属性会被设置为Integer类型,比如status、sort等,在这里,使用Integer类型参数作为条件时,要注意一点:例如
<if test="bean.activitySort != null and bean.activitySort !=""">
AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR}
</if>这里对于bean.activitySort的判断正常情况下如果activitySort是String类型,先判空,再判断是否是空字符串,这样是正常的,但是如果activitySort是Integer类型参数,那么使用时就需要注意,此处不能对activitySort进行空字符串的判断,因为什么呢?
因为mybatis在解析Integer类型数据时
如果数据值为0,会将0解析为空字符串,这样你传入的参数就成为无效的了,所以正常使用Integer类型参数应该是下面这样:
<if test="bean.activitySort != null">
AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR}
</if>以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
SpringBoot 在IDEA中实现热部署步骤详解(实用版)
这篇文章主要介绍了SpringBoot 在IDEA中实现热部署步骤详解(实用版),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-12-12
SpringBoot服务设置禁止server.point端口的使用
本文主要介绍了SpringBoot服务设置禁止server.point端口的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2024-01-01
Spring Session(分布式Session共享)实现示例
这篇文章主要介绍了Spring Session(分布式Session共享)实现示例,文章内容详细,需要的朋友可以参考下2023-01-01
SpringBoot参数校验:@Valid与@Validated使用详解
这篇文章主要介绍了SpringBoot参数校验:@Valid与@Validated使用详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2025-03-03


最新评论