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

网友投稿 497 2022-08-21


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

目录mybatisIntegehttp://r类型参数动态sql注意条件例如以下拼接的动态sqlmybatis的坑——Integer类型参数解析问题有时候我们使用实体类传递参数时因为mybatis在解析Integer类型数据时

mybatis Integer类型参数动态sql注意条件

例如以下AQylumsI拼接的动态sql

and T.status=#{work_status,jdbcType=INTEGER}

当work_status为0时,Mybatis会将0解析为了空字符串‘’,这样if判断就为false,如果想正确添加and后的查询条件,应该改成

and T.status=#{work_status,jdbcType=INTEGER}

mybatis的坑——Integer类型参数解析问题

有时候我们使用实体类传递参数时

有些属性会被设置为Integer类型,比如status、sort等,在这里,使用Integer类型参数作为条件时,要注意一点:例如

AND activity_sort = #{bean.activitySort,jdbcType=VARAQylumsICHAR}

这里对于bean.activitySort的判断正常情况下如果activitySort是String类型,先判空,再判断是否是空字符串,这样是正常的,但是如果activitySort是Integer类型参数,那么使用时就需要注意,此处不能对activitySort进行空字符串的判断,因为什么呢?

因为mybatis在解析Integer类型数据时

如果数据值为0,会将0解析为空字符串,这样你传入的参数就成为无效的了,所以正常使用Integer类型参数应该是下面这样:

AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring Cloud Ribbon 中的 7 种负载均衡策略的实现方法
下一篇:mybatis参数String与Integer类型的判断方式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~