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

  今天在工作中,发现一个带有java.util.Date类型入参的查询报错,异常信息:invalid comparison: java.util.Date and java.lang.String。网上查到的这篇文章和我正好总结了:http://blog.csdn.net/wanghailong_qd/article/details/50673144,特记录一下。

  工作的项目是Spring+MyBatis+MySQL的,对应实体类中有一个属性。

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都没问题啊。原来这是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>

 

文章来源:http://blog.csdn.net/wanghailong_qd/article/details/50673144

posted on 2017-07-25 00:40  bijian1013  阅读(1175)  评论(0)    收藏  举报

导航