MyBatis数组与集合判断空问题
作者:dxyzhbb
MyBatis数组与集合判断空
数组判断空
参数为数组object[]。在MyBatis判断空时,先判断是否为null,不为null则判断数组长度object.length是否大于0即可。
<if test="object!=null and object.length>0"> <yourSql> </if>
集合判断空
参数为集合List。在MyBatis判断空时,先判断是否为null,不为null则判断集合长度object.size()是否大于0即可。
<if test="object!=null and object.size()>0"> <yourSql> </if>
Mybatis判断空字符串
先说结论,如果使用正确,是不会产生任何问题的。大家各种疑惑,全是使用不当产生的。
先说正确的使用方式,一般判空的方式就是:
非String类型使用obj != null即可
String类型通常要加一个空串的判断obj != null and obj != '',如果入参类型对应的判断方式使用正确,不会有问题。
但是有很多做事不认真的人,会把这两个用反,虽然没报错,但是逻辑却不是预想中的,错误的使用例子就是,入参是一个数字类型,如Long,但是在判空时使用obj != null and obj != '',这种做法本身就是错误的,你会发现,当Long值传0的时候,obj != ''是成立的,就导致了完全出乎预料的结果。
其中mybatis的处理方式是,当发现你用一个数字类型的对象和串比较的时候,他会将串转换成数字类型,非空串的时候是没有问题的,空串的时候,mybatis将空串转换成数字0,这就是mybatis做的实现,没有什么漏洞,问题根源是对非字符串类型做了空串判断的错误操作。
最后的结论就是,数字类型的对象不要使用空串判断表达式obj != ''。
还有一个题外话:
两个系统交互时,数据在网络传输时是不具备类型的,只是到了端时,才会进行类型识别,我们通常和前端交互,数据在传输过程中都是串,也就是没有null这种,所以后端接收时规定的类型就非常重要了,需要注意的情况就是后端定义String类型时,不会出现null(除非前端没有传递这个参数),只会是空字符串,所以在判断时需要注意。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。