这篇文章主要介绍了mybatis中if-test数字判断的坑及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
if-test数字判断的坑
在项目中偶然发现一个判断数字的if没有起任何作用,代码如下
<if test="timeType !=null and timeType!='' and timeType == '3'">
AND
...
</if>经过查询资料发现,mybatis是用OGNL表达式来解析的,在OGNL的表达式中,数字’3’会被解析成字符,java是强类型的,char 和 一个string 会导致不等,所以if标签中的sql不会被解析。
所以应该改为:
<if test="timeType !=null and timeType!='' and timeType == '3'.toString() ">
AND
...
</if>然后发现确实解决了这个问题,特此记录。
mybatis的test判断注意事项
在使用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中 if-test 数字判断的坑及解决
基础教程推荐
- 一文带你搞懂Java中方法重写与方法重载的区别 2023-07-14
- MyBatis-Plus自定义通用的方法实现 2023-07-15
- Java实现插入排序算法可视化的示例代码 2023-04-23
- RocketMQ Push 消费模型示例详解 2023-05-24
- Java Web开发中过滤器和监听器使用详解 2023-06-30
- java知识点7——面向过程和面向对象、面向对象的内存分析、构造方法 2023-09-01
- 关于Java双大括号{{}}的具体使用 2023-03-15
- Spring Cloud Config分布式配置中心使用介绍详解 2023-05-07
- Java List的get方法 2023-10-08
- Java多线程学习笔记之三内存屏障与Java内存模型 2023-09-01
