Mybatis日期检索格式报错

问题复现

bash 复制代码
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
### Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

问题分析

看起来问题是因为查询的时候尝试将数据库中的日期(start_time)与字符串(startTime)进行比较,导致了 "java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String" 错误。

html 复制代码
------------------原Mybatis语句
 <if test="startTime != null and startTime != '' ">and chat.start_time = #{startTime}</if>
html 复制代码
------------------修复后Mybatis语句
   <if test="startTime != null "> and DATE_FORMAT(chat.start_time, '%Y-%m-%d')=DATE_FORMAT( #{startTime}, '%Y-%m-%d')</if>

问题反思

遇到的问题是由于 MyBatis 试图将数据库中的日期(chat.start_time)与字符串(startTime)进行比较,从而导致了 "java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String" 错误。通过将 startTime 参数直接与数据库中的日期进行比较,并使用 DATE_FORMAT 函数将它们都格式化为相同的日期字符串,您成功地解决了此问题。这样的修改是有效的,因为它确保了在比较时两者都具有相同的格式,因此不再引发类型不匹配的异常。现在查询将 chat.start_timestartTime 参数的日期字符串进行比较,这是一个可行的方法,前提是这两者的格式匹配。

相关推荐
日月云棠9 小时前
各版本JDK对比:JDK 25 特性详解
java
用户83071968408210 小时前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide10 小时前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家10 小时前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺10 小时前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户9083246027310 小时前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端
桦说编程11 小时前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化
程序员清风15 小时前
用了三年AI,我总结出高效使用AI的3个习惯!
java·后端·面试
beata16 小时前
Java基础-13: Java反射机制详解:原理、使用与实战示例
java·后端
用户03321266636716 小时前
Java 使用 Spire.Presentation 在 PowerPoint 中添加或删除表格行与列
java