关于mybatis遇到Integer类型的参数时动态sql需要注意条件

作者:yangyansong789 时间:2021-10-13 04:59:39 

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解析为了空字符串&lsquo;&rsquo;,这样if判断就为false,如果想正确添加and后的查询条件,应该改成

<if test="work_status !=null  ">
 and T.status=#{work_status,jdbcType=INTEGER}
</if>

mybatis的坑&mdash;&mdash;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
  • asp之家 软件编程 m.aspxhome.com