时间:2023-02-20 09:45:58 | 栏目:JAVA代码 | 点击:次
<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>
有些属性会被设置为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进行空字符串的判断,因为什么呢?
如果数据值为0,会将0解析为空字符串,这样你传入的参数就成为无效的了,所以正常使用Integer类型参数应该是下面这样:
<if test="bean.activitySort != null"> AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR} </if>