关于mybatis遇到Integer类型的参数时动态sql需要注意条件
关于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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~