Mybatis判断空字符串的问题

作者:诗人不写诗 时间:2022-11-18 02:07:00 

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判断为空注意

Mybatis判断空字符串的问题

startBalance java中是BigDecimal类型

这样写,startBalance != ‘’ 会返回false ,所以对象不能判断 != ‘’ ;

普通的String是可以的…

来源:https://blog.csdn.net/tales522/article/details/100066754

标签:Mybatis,判断,空字符串
0
投稿

猜你喜欢

  • Android应用中加入微信分享简单方法

    2022-06-05 00:17:27
  • centos7下安装java及环境变量配置技巧

    2022-06-05 08:06:13
  • Android电量优化提高手机续航

    2022-06-14 11:39:40
  • Java 迪杰斯特拉算法实现查找最短距离的实现

    2022-05-23 01:47:43
  • java使用Jdom实现xml文件写入操作实例

    2022-09-30 02:38:23
  • java如何获取map中value的最大值

    2023-04-11 05:12:04
  • 详解C#中的定时器Timer类及其垃圾回收机制

    2021-07-21 10:57:39
  • C# 实现dataGridView选中一行右键出现菜单的示例代码

    2022-05-12 05:15:55
  • Spring rest接口中的LocalDateTime日期类型转时间戳

    2022-11-20 14:00:00
  • 结合线程池实现apache kafka消费者组的误区及解决方法

    2023-08-06 15:40:31
  • Java SpringBoot 使用拦截器作为权限控制的实现方法

    2023-04-18 01:41:58
  • JavaWeb使用Cookie模拟实现自动登录功能(不需用户名和密码)

    2021-09-06 00:15:03
  • 全面解析Java支持的数据类型及Java的常量和变量类型

    2022-03-25 16:54:10
  • Dubbo实现分布式日志链路追踪

    2023-08-23 21:00:54
  • mybatis报错元素内容必须由格式正确的字符数据或标记组成异常的解决办法

    2023-01-10 15:46:37
  • Android使用Intent.ACTION_SEND分享图片和文字内容的示例代码

    2023-12-17 02:57:28
  • Android编程实现AIDL(跨进程通信)的方法详解

    2022-08-29 00:19:23
  • 浅析Java随机数与定时器

    2022-06-04 16:21:10
  • android中图片加载到内存的实例代码

    2023-05-23 06:04:35
  • 逐步讲解快速排序算法及C#版的实现示例

    2022-09-09 14:36:19
  • asp之家 软件编程 m.aspxhome.com