由于数据库中将审核状态字段定义的是
audit_status:审核状态 0:待审核;1:审核通过
但是在Mybatis xml文件中的写法是下面这样,导致if标签判断一直不生效
<if test="caseLibraryDTO.auditStatus != null and caseLibraryDTO.auditStatus != '' ">
and a.audit_status = #{caseLibraryDTO.auditStatus}
</if>
原因是由于字段定义的是number类型,mybatis if标签的 !=’ ’ 会将number类型的判断默认为 false,所以导致判断不成功
//只有对于String类型的字段才需要做 !='' 的判断
caseLibraryDTO.auditStatus != ''
将上面这个条件判断去掉直接写成下面这样即可,或者在对字段定义的时候避免为 “0”
<if test="caseLibraryDTO.auditStatus != null">
and a.audit_status = #{caseLibraryDTO.auditStatus}
</if>
Mybatis XML if 标签对数字类型字段的误判问题及解决方案
博客讨论了在Mybatis XML文件中,if标签对于数字类型字段判断时出现的问题。当字段audit_status定义为0(待审核)和1(审核通过)时,if标签的`!=''`条件导致判断失败,因为这适用于字符串而非数字类型。解决方案是去除不必要的判断条件,或者在定义字段时避免使用'0'作为默认值。修复后的if标签只需判断字段是否为null。

1932

被折叠的 条评论
为什么被折叠?



