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

相关文章

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

Python如何精准判断某个进程是否在运行

《Python如何精准判断某个进程是否在运行》这篇文章主要为大家详细介绍了Python如何精准判断某个进程是否在运行,本文为大家整理了3种方法并进行了对比,有需要的小伙伴可以跟随小编一起学习一下... 目录一、为什么需要判断进程是否存在二、方法1:用psutil库(推荐)三、方法2:用os.system调用