java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
2016-07-24 09:03
633 查看
原址:点击打开
问题:mybatis 新版本那事件类型入参与空字符串比较抛异常
解决如下:
开发中改动mapper文件后需要重新编译发布, 由于工程比较大非常耗时, 所以为方便快速测试干脆写了一个小Java工程. 工程中用到的dao, mapper和实体类都是从工程中拷出来的, 数据库也是同一个. 但是遇到一个比较奇怪的问题
实体类中有一个属性
对应该属性数据库中定义的是
mapper中该属性映射的定义
以下是mapper中对应Dao方法SQL语句
其中date()函数只是用来把年月日时分秒的日期截取为年月日, 这个对于该异常没有任何影响
在测试类中创建实体并为其属性赋值
然后执行查询方法dao.selectByCreateTime(user)的时候就报错了
看样子是因为类型不符合, 但是想了想, Date类型对应MySQL的datetime, 以及mapper中jdbcType都没问题啊. 而且完全一样的东西在原工程中是完全正常的. 既然都是一样的代码, 那就找找俩工程有啥不一样的吧
首先是MySQL jar版本不同. 换成原工程中的版本也无效. 然后是mybatis jar版本不一样, 换成原工程中的版本问题就解决了!
原工程中配置的是mybatis-3.2.8, 而我测试工程中用的是mybatis-3.3.0. 后来在网上找了一下才知道, 原来这是mybatis 3.3.0中对于时间参数进行比较时的一个bug. 如果拿传入的时间类型参数与空字符串”进行对比判断则会引发异常. 所以在上面的代码中去该该判断, 只保留非空判断就正常了
改为
问题:mybatis 新版本那事件类型入参与空字符串比较抛异常
解决如下:
<if test="createTime != null"> date(create_time) = date(#{createTime,jdbcType=TIMESTAMP}) </if>
开发中改动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>
相关文章推荐
- maven启动 cannot be cast to javax.servlet.Filter/cannot be cast to javax.servlet.Servlet 报错
- java中的final
- java中的泛型
- java - 利用cookie实现记住用户名方便之后登陆
- "Start Ruble bundle manager". java.lang.NullPointerException
- Java千百问_09基础类库(002)_util包有什么功能
- Java Web学习(19):阶段项目之使用JSP+JavaBean完成用户登录
- Java千百问_09基础类库(001)_lang包有什么功能
- java中String类的hashCode方法实现
- Java-基础-代码块-继承--关键字
- JavaWeb ChartDirector 图表插件-web图表开发-ChartDirector资料
- java-基础-计算数组的转置(横向输出)
- 15个Java的报表工具简介
- java-抽象类和接口的作用
- Eclipse中,No compiler is provided in this environment. Perhaps you are running on a JRE rather than a
- 深入理解java反射机制
- JAVA集合体系回顾(2)
- JAVA面向对象-----接口与类、接口之间的关系
- JAVA面向对象-----接口与类、接口之间的关系
- JAVA面向对象-----接口的特点