失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mybatis异常invalid comparison: java.util.Date and java.lang.String

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

时间:2022-11-15 10:25:16

相关推荐

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

原文链接:/wanghailong_qd/article/details/50673144

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

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

实体类中有一个属性

[java]view plaincopy privateDatecreateTime;

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

[sql]view plaincopy create_timedatetime

mapper中该属性映射的定义

[html]view plaincopy <resultcolumn="create_time"property="createTime"jdbcType="TIMESTAMP"/>

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

[html]view plaincopy <selectid="selectByCreateTime"resultMap="userMap">select*fromuser<where><iftest="createTime!=nullandcreateTime!=''">date(create_time)=date(#{createTime,jdbcType=TIMESTAMP})</if></where></select>

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

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

[java]view plaincopy Useruser=newUser();user.setCreateTime(newSimpleDateFormat("yyyy-MM-dd").parse("-01-18"));

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

[java]view plaincopy Exceptioninthread"main"org.apache.ibatis.exceptions.PersistenceException:###Errorqueryingdatabase.Cause:java.lang.IllegalArgumentException:invalidcomparison:java.util.Dateandjava.lang.String###Cause:java.lang.IllegalArgumentException:invalidcomparison:java.util.Dateandjava.lang.Stringatorg.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30)atorg.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:122)atorg.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:113)atorg.apache.ibatis.binding.MapperMethod.executeForMany(MapperMethod.java:122)atorg.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:64)atorg.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)atcom.sun.proxy.$Proxy0.selectByCreateTime(UnknownSource)atmybatis.Test.buyerInfoTimeTest(Test.java:53)atmybatis.Test.main(Test.java:39)Causedby:java.lang.IllegalArgumentException:invalidcomparison:java.util.Dateandjava.lang.Stringatorg.apache.ibatis.pareWithConversion(OgnlOps.java:92)atorg.apache.ibatis.ognl.OgnlOps.isEqual(OgnlOps.java:142)atorg.apache.ibatis.ognl.OgnlOps.equal(OgnlOps.java:794)atorg.apache.ibatis.ognl.ASTNotEq.getValueBody(ASTNotEq.java:53)atorg.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)atorg.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)atorg.apache.ibatis.ognl.ASTAnd.getValueBody(ASTAnd.java:61)atorg.apache.ibatis.ognl.SimpleNode.evaluateGetValueBody(SimpleNode.java:212)atorg.apache.ibatis.ognl.SimpleNode.getValue(SimpleNode.java:258)atorg.apache.ibatis.ognl.Ognl.getValue(Ognl.java:494)atorg.apache.ibatis.ognl.Ognl.getValue(Ognl.java:458)atorg.apache.ibatis.scripting.xmltags.OgnlCache.getValue(OgnlCache.java:44)atorg.apache.ibatis.scripting.xmltags.ExpressionEvaluator.evaluateBoolean(ExpressionEvaluator.java:32)atorg.apache.ibatis.scripting.xmltags.IfSqlNode.apply(IfSqlNode.java:34)atorg.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)atorg.apache.ibatis.scripting.xmltags.TrimSqlNode.apply(TrimSqlNode.java:55)atorg.apache.ibatis.scripting.xmltags.MixedSqlNode.apply(MixedSqlNode.java:33)atorg.apache.ibatis.scripting.xmltags.DynamicSqlSource.getBoundSql(DynamicSqlSource.java:41)atorg.apache.ibatis.mapping.MappedStatement.getBoundSql(MappedStatement.java:280)atorg.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:80)atorg.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:120)...7more

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

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

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

[html]view plaincopy <iftest="createTime!=nullandcreateTime!=''">date(create_time)=date(#{createTime,jdbcType=TIMESTAMP})</if>

改为

[html]view plaincopy <iftest="createTime!=null">date(create_time)=date(#{createTime,jdbcType=TIMESTAMP})</if>

如果觉得《mybatis异常invalid comparison: java.util.Date and java.lang.String》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。