开发者

MyBatis数组与集合判断空问题

目录
  • ​MyBATis数组与集合判断空
    • 数组判断空
    • 集合判断空
  • ​Mybatis判断空字符串
    • 总结

      ​MyBatis数组与集合判断空

      数组判断空

      参数为数组object[]。在MyBatis判断空时,先判断是否为null,不为null则判断数组长度object.length是否大于0即可。

      	<if test="object!=null and object.length>0">
      		<yourSql>
      	</if&g编程t;

      集合判断空

      参数为集合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 ociSWAFbj != '',如果入参类型对应的判断方式使用正确,不会有问题。

      但是有很多做事不认真的人,会把这两个用反,虽然没报错,但是逻辑却不是预想中的,错误的使用例子就是,入参是一个数字类型,如Long,但是在判空时使用obj != null and obj != '',这种做法本身就是错误的,你会发现,当Long值传0的时候,obj != ''是成立的,就导致了完全出乎预料的结果。

      其中mybatis的处理方式是,当发现你用一个数字类型的对象和串比较的时候,他会将串转换成数字类型,非空串的时候是没有问题的,空串的时候,mybatis将空串转换成数字0,这就是mybatandroidis做的实现,没有什么漏洞,问题根源是对非字符串类型做了空串判断的错误操作。

      最后的结论就是,数字类型的对象不要使用空串判断表达式obj www.devze.com!= ''。

      还有一个题外话:

      两个系统交互时,数据在网络传输时是不具备类型的,只是到了端时,才会进行类型识别,我们通常和前端交互,数据在传输过程中都是串,也就是没有null这种,所以后端接收时规定的类型就非常重要了,需开发者_JS培训要注意的情况就是后端定义String类型时,不会出现null(除非前端没有传递这个参数),只会是空字符串,所以在判断时需要注意。

      总结

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

      0

      上一篇:

      下一篇:

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      最新开发

      开发排行榜