zoukankan      html  css  js  c++  java
  • mybatis异常invalid comparison: java.util.Date and java.lang.String

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


    实体类中有一个属性

    1. private Date createTime;  

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

    1. create_time datetime  


    mapper中该属性映射的定义

    1. <result column="create_time" property="createTime" jdbcType="TIMESTAMP" />  


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

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

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

    1. User user=new User();  
    2. user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));  

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

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


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

    改为

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


    原文出处:http://blog.csdn.net/wanghailong_qd/article/details/50673144

    关注公众号,分享干货,讨论技术


  • 相关阅读:
    大龄开发人员如何破局
    在c++MFC下用PCL显示操作点云文件 MFC对话框显示操作PCL点云
    记录学习图像处理过程中不错的教程博客
    做三维模型识别目标定位配准测量的有关资料记录
    OpenCASCADE(一) VS2017+OpenCASCADE+MFC +win10下载配置安装运行单文档程序画个基本图形
    关于opengl中的三维矩阵平移代码,矩阵旋转代码,推导过程理解 OpenGL计算机图形学的一些必要矩阵运算知识 glTranslatef(x,y,z)glRotatef(angle,x,y,z)函数详解
    深度学习系列教程目录
    c/c++ 2019公司面试题目录
    c++ 知道旋转平移变换前后矩阵向量值 求旋转变换矩阵c++/c#代码 知道两个向量求他们的旋转变换矩阵
    OpenCV与MFC实战之图像处理 样本采集小工具制作 c++MFC课程设计
  • 原文地址:https://www.cnblogs.com/molashaonian/p/9097574.html
Copyright © 2011-2022 走看看