Mybatis判断空字符串的问题
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(除非前端没有传递这个参数),只会是空字符串,所以在判断时需要注意。
Mybatis判断为空注意

startBalance java中是BigDecimal类型
这样写,startBalance != ‘’ 会返回false ,所以对象不能判断 != ‘’ ;
普通的String是可以的…
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
jstack报错Unable to open socket file解决
这篇文章主要为大家介绍了jstack报错Unable to open socket file的解决方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2024-02-02
解决Java Redis删除HashMap中的key踩到的坑
这篇文章主要介绍了解决Java Redis删除HashMap中的key踩到的坑,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2021-02-02
Spring Boot Starter 的应用场景与自动配置方式
本文介绍了Spring Boot Starter的使用场景,如何自定义Starter以及Spring Boot自动配置原理,Spring Boot Starter解决了依赖导入和配置繁琐的问题,通过自动配置类和xxxProperties类实现组件的自动注入和配置,感兴趣的朋友一起看看吧2025-03-03
5分钟快速学会spring boot整合JdbcTemplate的方法
这篇文章主要给大家介绍了如何通过5分钟快速学会spring boot整合JdbcTemplate的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用spring boot整合JdbcTemplate具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧2019-12-12


最新评论