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和實體類都是從工程中拷出來的, 數據庫也是同一個. 但是遇到一個比較奇怪的問題

 

實體類中有一個屬性

 

[java]  view plain  copy
 
  1. private Date createTime;  

對應該屬性數據庫中定義的是

 

[sql]  view plain  copy
 
  1. create_time datetime  

 


mapper中該屬性映射的定義

 

[html]  view plain  copy
 
  1. <result column="create_time" property="createTime" jdbcType="TIMESTAMP" />  

 


以下是mapper中對應Dao方法SQL語句

 

[html]  view plain  copy
 
  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()函數只是用來把年月日時分秒的日期截取為年月日, 這個對於該異常沒有任何影響

在測試類中創建實體並為其屬性賦值

 

[java]  view plain  copy
 
  1. User user=new User();  
  2. user.setCreateTime(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-18"));  

 

然后執行查詢方法dao.selectByCreateTime(user)的時候就報錯了

 

[java]  view plain  copy
 
  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. 如果拿傳入的時間類型參數與空字符串''進行對比判斷則會引發異常. 所以在上面的代碼中去該該判斷, 只保留非空判斷就正常了

 

 

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

 

改為

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM