mybaits3.3.0date类型数据判断非空报错

2024-03-10 06:58

本文主要是介绍mybaits3.3.0date类型数据判断非空报错,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开发中改动mapper文件后需要重新编译发布, 由于工程比较大非常耗时, 所以为方便快速测试干脆写了一个小java工程. 工程中用到的dao, mapper和实体类都是从工程中拷出来的, 数据库也是同一个. 但是遇到一个比较奇怪的问题

 

实体类中有一个属性

 

private Date createTime;

 

对应该属性数据库中定义的是

 

create_time datetime

 

 

 

mapper中该属性映射的定义

 

<result column="create_time" property="createTime" jdbcType="TIMESTAMP" />

 

 

 

以下是mapper中对应Dao方法SQL语句

 

 
  1. <select id="selectByCreateTime" resultMap="userMap">

  2. select * from user

  3. <where>

  4. <if test="createTime != null and createTime !='' " >

  5. date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

  6. </if>

  7. </where>

  8. </select>

 

其中date()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响

在测试类中创建实体并为其属性赋值

 

 
  1. User user=new User();

  2. user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));

 

 

然后执行查询方法dao.selectByCreateTime(user)的时候就报错了

 

 
  1. Exception in thread "main" org.apache.ibatis.exceptions.PersistenceException:

  2. ### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

  3. ### Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

  4. at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)

  5. at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:122)

  6. at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:113)

  7. at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:122)

  8. at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:64)

  9. at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)

  10. at com.sun.proxy.$Proxy0.selectByCreateTime(Unknown Source)

  11. at mybatis.Test.buyerInfoTimeTest(Test.java:53)

  12. at mybatis.Test.main(Test.java:39)

  13. Caused by: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String

  14. at org.apache.ibatis.ognl.OgnlOps.compareWithConversion(OgnlOps.java:92)

  15. at org.apache.ibatis.ognl.OgnlOps.isEqual(OgnlOps.java:142)

  16. at org.apache.ibatis.ognl.OgnlOps.equal(OgnlOps.java:794)

  17. at org.apache.ibatis.ognl.ASTNotEq.getValueBody(ASTNotEq.java:53)

  18. at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)

  19. at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)

  20. at org.apache.ibatis.ognl.ASTAnd.getValueBody(ASTAnd.java:61)

  21. at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)

  22. at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)

  23. at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:494)

  24. at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:458)

  25. at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:44)

  26. at org.apache.ibatis.scripting.xmltags.ExpressionEvaluator.evaluateBoolean(ExpressionEvaluator.java:32)

  27. at org.apache.ibatis.scripting.xmltags.IfSqlNode.apply(IfSqlNode.java:34)

  28. at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)

  29. at org.apache.ibatis.scripting.xmltags.TrimSqlNode.apply(TrimSqlNode.java:55)

  30. at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)

  31. at org.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:41)

  32. at org.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:280)

  33. at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:80)

  34. at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:120)

  35. ... 7 more



看样子是因为类型不符合, 但是想了想, Date类型对应MySQL的datetime, 以及mapper中jdbcType都没问题啊. 而且完全一样的东西在原工程中是完全正常的. 既然都是一样的代码, 那就找找俩工程有啥不一样的吧

 

 

首先是mysql jar版本不同. 换成原工程中的版本也无效. 然后是mybatis jar版本不一样, 换成原工程中的版本问题就解决了!

 

原工程中配置的是mybatis-3.2.8, 而我测试工程中用的是mybatis-3.3.0.后来在网上找了一下才知道, 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串''进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了

 

 

 
  1. <if test="createTime != null and createTime !='' " >

  2. date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

  3. </if>

 
 

 

改为

 

 
  1. <if test="createTime != null">

  2. date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})

  3. </if>

这篇关于mybaits3.3.0date类型数据判断非空报错的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/793419

相关文章

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S