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>
来源:https://blog.csdn.net/yangyansong789/article/details/80618116
标签:mybatis,Integer,参数,动态sql
0
投稿
猜你喜欢
Spring超详细讲解创建BeanDefinition流程
2023-11-25 08:37:55
聊聊关于Java方法重写的反思
2022-10-26 00:36:12
Java值传递之swap()方法不能交换的解决
2023-11-12 20:54:50
java分割文本字符串的方法
2023-11-13 03:52:24
Android Service详解及示例代码
2021-12-24 05:44:17
SpringCloud消息总线Bus配置中心实现过程解析
2023-02-14 10:05:18
C#实现扫描枪扫描二维码并打印(实例代码)
2023-02-26 18:02:56
基于JavaMail API收发邮件的方法
2022-03-10 09:34:24
WPF自定义实现IP地址输入控件
2022-02-24 05:35:36
Spring boot 连接多数据源过程详解
2023-11-28 12:09:51
迅速掌握Java容器中常用的ArrayList类与Vector类用法
2022-12-16 16:18:47
Java中线程状态+线程安全问题+synchronized的用法详解
2023-08-23 08:38:07
详解Java线程池队列中的延迟队列DelayQueue
2023-08-30 01:22:04
Java使用sftp定时下载文件的示例代码
2022-11-14 06:11:47
详解java中产生死锁的原因及如何避免
2022-04-22 00:36:14
MyBatis图文并茂讲解注解开发一对一查询
2023-12-07 11:01:18
C#使用linq查询大数据集的方法
2023-05-24 16:52:17
详解Java弱引用(WeakReference)的理解与使用
2022-07-13 12:37:32
java通过PDF模板填写PDF表单
2022-05-28 16:37:48
SpringBoot2.0集成WebSocket实现后台向前端推送信息
2023-08-22 18:50:39