在使用mybatis进行判断的时候,一定要注意传入的数据类型与判断的目标值类型是否一致。
最近在一次开发过程,误将一个传入的整型数据使用了下面的判断方式:
<if test="appType != null and appType != ''">
and a.c_appType = #{appType}
</if>
其中,appType是一个整型数据。可以看到,在test判断里面使用了 appType != ''。在进行业务功能测试的时候发现,当传入的值是0时,该条件筛选没有起作用,通过调试发现,mybatis会将空字符串转换成double类型的0.0,如下图所示:

同样的,整数数据也会转换为double类型,如下图所示:

所以,mybatis在判断的时候,数字0和空字符串是相等的,而我们的if判断里,是两者不相等时该条件才会起作用。因此,在使用mybatis判断的时候,一定要注意类型是否一致,数字类型就不要判断空字符串的情况了。
在使用MyBatis进行条件判断时,需确保传入数据类型与目标值类型一致。文章详细解析了一次因类型不匹配导致的业务功能测试失败案例,强调在进行数字类型判断时避免与空字符串比较的重要性。
8万+

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



