mybatis部分版本異常invalid comparison: java.util.Date and java.lang.String


嚴重: Servlet.service() for servlet [spring] in context with path [] threw exception [Request processing failed; nested exception is org.mybatis.spring.MyBatisSystemException: nested exception is 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] with root cause

java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
at org.apache.ibatis.ognl.OgnlOps.compareWithConversion(OgnlOps.java:93)
at org.apache.ibatis.ognl.OgnlOps.isEqual(OgnlOps.java:143)
at org.apache.ibatis.ognl.OgnlOps.equal(OgnlOps.java:802)
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)
。。。。

 

表面上看是因為類型不符合, 但是想了想, Date類型對應MySQL的datetime, 以及mapper中jdbcType都沒問題啊. 而且完全一樣的東西在原工程中是完全正常的. 既然都是一樣的代碼, 那就找找倆工程有啥不一樣的吧

首先是MySQL jar版本不同. 換成原工程中的版本也無效. 然后是mybatis jar版本不一樣, 換成原工程中的版本問題就解決了!

原工程中配置的是mybatis-3.2.8, 而我測試工程中用的是mybatis-3.3.1.后來在網上找了一下才知道了原因:

    原來這是mybatis 3.3.0中對於時間參數進行比較時的一個bug. 如果拿傳入的時間類型參數與空字符串''進行對比判斷則會引發異常. 所以在上面的代碼中去該該判斷, 只保留非空判斷就正常了

 

例如:在xxMapper.xml的把

<update id="updAccount" parameterType="com.isoftstone.ci.user.domain.Account" >
update usr_account set 
<trim  suffixOverrides="," >
<if test="sysAccountType != null  ">
sys_account_type=#{sysAccountType},
</if>
<if test="realNameAuthed != null  ">
real_name_authed=#{realNameAuthed},
</if>
<if test="lastLoginAt != null and lastLoginAt != ' ' ">
last_login_at=#{lastLoginAt}
</if>

</trim>
where id=#{id}
</update>

將代碼換下面的代碼(去掉時間跟空字符串的比較 lastLoginAt != ' ')

 

<update id="updAccount" parameterType="com.isoftstone.ci.user.domain.Account" >
update usr_account set 
<trim  suffixOverrides="," >
<if test="sysAccountType != null  ">
sys_account_type=#{sysAccountType},
</if>
<if test="realNameAuthed != null  ">
real_name_authed=#{realNameAuthed},
</if>
<if test="lastLoginAt != null ">
last_login_at=#{lastLoginAt}
</if>

</trim>
 where id=#{id}
</update>


免責聲明!

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



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