mybatis异常invalid comparison: java.util.Date and java.lang.String
原文链接:http://blog.csdn.net/wanghailong_qd/article/details/50673144
mybatis异常invalid comparison: java.util.Date and java.lang.String
开发中改动mapper文件后需要重新编译发布, 由于工程比较大非常耗时, 所以为方便快速测试干脆写了一个小java工程. 工程中用到的dao, mapper和实体类都是从工程中拷出来的, 数据库也是同一个. 但是遇到一个比较奇怪的问题
实体类中有一个属性
- private Date createTime;
对应该属性数据库中定义的是
- create_time datetime
mapper中该属性映射的定义
- <result column="create_time" property="createTime" jdbcType="TIMESTAMP" />
以下是mapper中对应Dao方法SQL语句
- <select id="selectByCreateTime" resultMap="userMap">
- select * from user
- <where>
- <if test="createTime != null and createTime !='' " >
- date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
- </if>
- </where>
- </select>
其中date()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响
在测试类中创建实体并为其属性赋值
- User user=new User();
- user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));
然后执行查询方法dao.selectByCreateTime(user)的时候就报错了
- Exception in thread "main" 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
- at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)
- at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:122)
- at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:113)
- at org.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:122)
- at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:64)
- at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)
- at com.sun.proxy.$Proxy0.selectByCreateTime(Unknown Source)
- at mybatis.Test.buyerInfoTimeTest(Test.java:53)
- at mybatis.Test.main(Test.java:39)
- Caused by: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
- at org.apache.ibatis.ognl.OgnlOps.compareWithConversion(OgnlOps.java:92)
- at org.apache.ibatis.ognl.OgnlOps.isEqual(OgnlOps.java:142)
- at org.apache.ibatis.ognl.OgnlOps.equal(OgnlOps.java:794)
- at org.apache.ibatis.ognl.ASTNotEq.getValueBody(ASTNotEq.java:53)
- at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)
- at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)
- at org.apache.ibatis.ognl.ASTAnd.getValueBody(ASTAnd.java:61)
- at org.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)
- at org.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)
- at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:494)
- at org.apache.ibatis.ognl.Ognl.getValue(Ognl.java:458)
- at org.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:44)
- at org.apache.ibatis.scripting.xmltags.ExpressionEvaluator.evaluateBoolean(ExpressionEvaluator.java:32)
- at org.apache.ibatis.scripting.xmltags.IfSqlNode.apply(IfSqlNode.java:34)
- at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)
- at org.apache.ibatis.scripting.xmltags.TrimSqlNode.apply(TrimSqlNode.java:55)
- at org.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)
- at org.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:41)
- at org.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:280)
- at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:80)
- at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:120)
- ... 7 more
看样子是因为类型不符合, 但是想了想, Date类型对应MySQL的datetime, 以及mapper中jdbcType都没问题啊. 而且完全一样的东西在原工程中是完全正常的. 既然都是一样的代码, 那就找找俩工程有啥不一样的吧
首先是mysql jar版本不同. 换成原工程中的版本也无效. 然后是mybatis jar版本不一样, 换成原工程中的版本问题就解决了!
原工程中配置的是mybatis-3.2.8, 而我测试工程中用的是mybatis-3.3.0.后来在网上找了一下才知道, 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串''进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了
- <if test="createTime != null and createTime !='' " >
- date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
- </if>
改为
- <if test="createTime != null">
- date(create_time) = date(#{createTime,jdbcType=TIMESTAMP})
- </if>
mybatis异常invalid comparison: java.util.Date and java.lang.String的更多相关文章
- mybatis部分版本异常invalid comparison: java.util.Date and java.lang.String
严重: Servlet.service() for servlet [spring] in context with path [] threw exception [Request processi ...
- java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
在重构项目的时候,遇到了mybatis的一个异常: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and ...
- java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和总结
在web开发中,避免不了对日期的操作,就几种常见的日期操作做个总结(部分参考网络,在此表示感谢): java.util.Date.java.sql.Date.java.sql.Time.java.sq ...
- java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和联系
java.util.Date.java.sql.Date.java.sql.Time.java.sql.Timestamp区别和联系 栏目:Java基础 作者:admin 日期:2015-04-19 ...
- java.util.Date与java.sql.Date
我数据库里用到了日期类型.用java编程的时候同时import了java.util.*和java.sql.*,发现直接申明Date类型 Date dt; 会报错,查了一下才发现有java.util.D ...
- java.util.Date和java.sql.Date的区别和相互转化
java.util.Date是在除了SQL语句的情况下面使用的.java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分它 们都有getTime方法返回毫秒数,自然就可以直接构建. ...
- java.util.Date和java.sql.Date的区别和相互转化(转)
java.util.Date是在除了SQL语句的情况下面使用的.java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分它们都有getTime方法返回毫秒数,自然就可以直接构建. ...
- java.util.Date和java.sql.Date的区别及应用
java.util.Date 就是在除了SQL语句的情况下面使用java.sql.Date 是针对SQL语句使用的,它只包含日期而没有时间部分它都有getTime方法返回毫秒数,自然就可以直接构建ja ...
- java.util.Date和java.sql.Date
java.util.Date是在除了SQL语句的情况下面使用的. java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分 它们都有getTime方法返回毫秒数,自然就可以直接构建 ...
随机推荐
- 20155330 《网络对抗》 Exp9 web安全基础实践
20155330 <网络对抗> Exp9 web安全基础实践 实验问题回答 SQL注入攻击原理,如何防御 原理:SQL注入攻击值得是通过构建特殊的输入作为参数传入web应用程序,而这些输入 ...
- mfc Edit控件属性
设置Edit控件属性 窗口创建顺序 初始化Edit控件数据 一.设置Edit控件属性 .Align Text :Right 二.窗口创建顺序 CMywindowdlg: 窗口构造函数 OnCreate ...
- 机器学习英雄访谈录之双料 Kaggle 大师:Dr. Jean-Francois Puget
目录 机器学习英雄访谈录之双料 Kaggle 大师:Dr. Jean-Francois Puget 正文 对我的启发 机器学习英雄访谈录之双料 Kaggle 大师:Dr. Jean-Francois ...
- Google Kickstart Round.B C. Diverse Subarray
这题又是万恶的线段树 maxx[j]存储的是 l = xxx, r = j的时候的答案 我们会让 l 从 1到n 的遍历中,查询线段树的[l, n]中最大的答案 因为query的下界是n,所以单次查询 ...
- 绕过用编码方式阻止XSS攻击的几个例子
阻止攻击的常用方法是:在将HTML返回给Web浏览器之前,对攻击者输入的HTML进行编码.HTML编码使用一些没有特定HTML意义的字符来代替那些标记字符(如尖括号).这些替代字符不会影响文本在web ...
- Mocha 单元测试框架简介
前言: mocha是JavaScript的一种单元测试框架,既可以在浏览器环境下运行,也可以在Node.js环境下运行. 使用mocha,我们就只需要专注于编写单元测试本身,然后,让mocha去自动运 ...
- io整理
http://www.cnblogs.com/rollenholt/archive/2011/09/11/2173787.html
- Beta阶段对团队成员公开感谢
我感谢付佳对我的帮助,因为Beta阶段她承担了一名组长责任,每次代码编写,安排任务都由她带头来做,并且在代码方面帮助我解决了一些问题.
- 11.4 Daily Scrum
今天依旧是学习阶段,大家继续学习安卓的一些相关内容,并尝试将要用到的数据的API应用到程序中去. Today's tasks Tomorrow's tasks 丁辛 餐厅列表json/xml数据 ...
- Linux内核分析——第一周学习笔记
20135313吴子怡.北京电子科技学院 chapter 1 知识点梳理 第一节 存储程序计算机工作模型 1.冯诺依曼体系结构:即具有存储程序的计算机体系结构.目前大多数拥有计算和存储功能的设备(智能 ...