原文链接:http://blog.csdn.net/wanghailong_qd/article/details/50673144

mybatis异常invalid comparison: java.util.Date and java.lang.String

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

实体类中有一个属性

[java] view plain copy
  1. private Date createTime;

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

[sql] view plain copy
  1. create_time datetime

mapper中该属性映射的定义

[html] view plain copy
  1. <result column="create_time" property="createTime" jdbcType="TIMESTAMP" />

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

[html] view plain copy
  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()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响

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

[java] view plain copy
  1. User user=new User();
  2. user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));

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

[java] view plain copy
  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. 如果拿传入的时间类型参数与空字符串''进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了

[html] view plain copy
  1. <if test="createTime != null and createTime !='' " >
  2. date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
  3. </if>

改为

[html] view plain copy
  1. <if test="createTime != null">
  2. date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
  3. </if>

转载于:https://www.cnblogs.com/libin6505/p/8567138.html

mybatis异常invalid comparison: java.util.Date and java.lang.String相关推荐

  1. 【明哥报错簿】之 mybatis异常invalid comparison: java.util.Date and java.lang.String

    [明哥报错簿]之 mybatis异常invalid comparison: java.util.Date and java.lang.String 参考文章: (1)[明哥报错簿]之 mybatis异 ...

  2. invalid comparison: java.util.Date and java.lang.String

    在使用mysql查询的时候,报的这个错误. invalid comparison: java.util.Date and java.lang.String 一.原因分析 <if test=&qu ...

  3. java8 util.time_Java8 java.util.Date转换为java.time.ZonedDateTime

    尝试将java.util.Date转换为java.time.LocalDate时,我收到以下异常. java.time.DateTimeException: Unable to obtain Zone ...

  4. 如何将java.util.Date转换为java.sql.Date?

    我试图使用java.util.Date作为输入,然后用它创建一个查询-所以我需要一个java.sql.Date . 我很惊讶地发现它不能隐式或显式地进行转换-但我什至不知道该怎么做,因为Java AP ...

  5. java.util.Date和java.sql.Date

    java.util.Date是在除了SQL语句的情况下面使用的. java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分 它们都有getTime方法返回毫秒数,自然就可以直接构建 ...

  6. java.util.Date和java.sql.Date之间的相互转换

    1.java.util.Date转换为java.sql.Date java.util.Date curDate = new java.util.Date(); java.sql.Date date = ...

  7. java.util.Date与 java.sql.Date两个包下Date的区别与联系

    一般我在项目中导入需要的包,大部分情况下都会根据IDE的提示自动导入默认的包,少数情况下会扫一眼,看看是不是需要的包,极少情况会斟酌一下,确认一下这就是需要的包. 最近在项目中导入JDK中的Date包 ...

  8. java.util.Date和java.sql.Date 一点区别

    最近无意中发现,在oracle中同一样的一个Date类型字段,存储的日期格式有两种不同的情况,第一种是2011-1-1 12:00:00,第二种是2011-1-1,仔细查找发现在向数据库中写数据的时候 ...

  9. java.util.Date和java.sql.Date的区别及应用

    ava.util.Date 就是在除了SQL语句的情况下面使用 java.sql.Date 是针对SQL语句使用的,它只包含日期而没有时间部分 它都有getTime方法返回毫秒数,自然就可以直接构建 ...

最新文章

  1. C++11中的bool变量不进行初始化,结果随机,可能是false也可能是true,所以一定要初始化
  2. android缓存之Lrucache 和LinkedHashMap
  3. 雷蛇灯光配置文件_没想到吧,雷蛇竟然出61键小尺寸机械键盘了!雷蛇猎魂光蛛迷你版上手...
  4. llvm编译linux,在Linux上编译LLVM/Clang 8.0.0等全部源代码
  5. k-Means——经典聚类算法实验(Matlab实现)
  6. ubuntu16.04下安装opencv3.2版本
  7. 后置“浴霸”六摄!疑似索尼全新旗舰Xperia 2曝光
  8. ERROR 1064 (42000): You have an error in your SQL syntax
  9. nvivo三天写论文!社会网络分析实战
  10. 制作自己的 Cydia 源
  11. 核子公式——量化IT团队绩效
  12. badboy设置中文_badboy中文手册
  13. 查看手机IMEI IMSI
  14. 交换机配置计算机mac地址吗,局域网管理,设置网络核心交换机,局域网电脑IP-MAC地址绑定...
  15. uniapp开发微信小程序,从构建到上线
  16. CF Div2 781
  17. No.13 Not Shading
  18. 04-前端技术_ javaScript内置对象与DOM操作
  19. 计算机科学主题 一亩三分地 考试 中心 满分95大米 (只适用于2019年 之后注册的新人) 答案
  20. wps姓名隐藏为星号_wps表格把重要数字隐藏用星号显示的方法步骤

热门文章

  1. JS数据结构与算法——冒泡排序(把大的数字依次往后放)
  2. Vue项目中使用百度地图API
  3. 四、PHP基础——会话技术Cookie 和 Session
  4. 十一、加权线性回归案例:预测鲍鱼的年龄
  5. 阿里云 超级码力在线编程大赛初赛 第2场 题目1. 三角魔法
  6. LeetCode 432. 全 O(1) 的数据结构(设计题)*
  7. LeetCode 990. 等式方程的可满足性(并查集)
  8. 逻辑斯谛回归模型( Logistic Regression,LR) 最大熵模型(Max Entropy,ME)
  9. LeetCode 202. 快乐数(快慢指针)
  10. Django搜索工具——全文检索