Mybatis中的jdbcType的做用

Mybatis中的jdbcType的做用

使用MyBatis框架作更新操做時,在該字段須要更新的內容爲空時,就會出現1111錯誤,也就是無效的列類型,這個時候你就要使用jdbcType。至於何時要使用到javaType我還沒遇到過,並且我也沒有據說過要使用javaType。

前天遇到一個問題 異常顯示以下: html

引用java


Exception in thread "main" org.springframework.jdbc.UncategorizedSQLException: Error setting null for parameter #6 with JdbcType OTHER . Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. Cause: java.sql.SQLException: 無效的列類型: 1111 
; uncategorized SQLException for SQL []; SQL state [99999]; error code [17004]; 無效的列類型: 1111; nested exception is java.sql.SQLException: 無效的列類型: 1111 spring



對應的sqlmap以下: sql

Xml代碼  收藏代碼數據庫

  1. <insert id="insertCustomerLog" parameterType="map">  
  2.       insert into customer_log  
  3.       (  
  4.       ID,  
  5.       CUSTOMER_SERVICE_USER_NAME,  
  6.       user_name,  
  7.       CONTENT,  
  8.       LOG_FIRST_TYPE,  
  9.       STATUS,  
  10.       LINKED_ID,  
  11.       FEE,  
  12.       ACCOUNT_FIRST_TYPE,  
  13.       ACCOUNT_SECOND_TYPE,  
  14.       ACCOUNT_THIRD_TYPE,  
  15.       LOG_SECOND_TYPE,  
  16.       LOG_IP,  
  17.       MEMO  
  18.       )  
  19.       values  
  20.       (  
  21.              seq_customer_log.nextval ,  
  22.             #{customerServiceUserName} ,  
  23.             #{username},  
  24.             #{content},  
  25.             #{logFirstType},  
  26.             #{status},  
  27.             #{linkedId},  
  28.             #{fee},  
  29.             #{accountFirstType},  
  30.             #{accountSecondType},  
  31.             #{accountThirdType},  
  32.             #{logSecondType},  
  33.             #{logIp},  
  34.             #{memo}  
  35.       )  
  36.   </insert>  



查詢了一下 一些資料說是: 
 apache

引用mybatis


MyBatis 插入空值時,須要指定JdbcType 
mybatis insert空值報空值異常,可是在pl/sql不會提示錯誤,主要緣由是mybatis沒法進行轉換, oracle



因此將xml改成: 框架

Xml代碼  收藏代碼dom

  1. <insert id="insertCustomerLog1" parameterType="com.diyicai.customer.domain.CustomerLog">  
  2.         insert into customer_log  
  3.                (  
  4.                ID,  
  5.                CUSTOMER_SERVICE_USER_NAME,  
  6.                user_name ,  
  7.                CONTENT,  
  8.                LOG_FIRST_TYPE,  
  9.                STATUS,  
  10.                LINKED_ID,  
  11.                FEE,  
  12.                ACCOUNT_FIRST_TYPE,  
  13.                ACCOUNT_SECOND_TYPE,  
  14.                ACCOUNT_THIRD_TYPE,  
  15.                LOG_SECOND_TYPE,  
  16.                LOG_IP,  
  17.                MEMO  
  18.                )  
  19.                values  
  20.                (  
  21.                seq_customer_log.nextval ,  
  22.                #{customerServiceUserName,jdbcType=VARCHAR} ,  
  23.                #{username,jdbcType=VARCHAR},  
  24.                #{content,jdbcType=VARCHAR},  
  25.                #{logFirstType,jdbcType=NUMERIC},  
  26.                #{status,jdbcType=NUMERIC},  
  27.                #{linkedId,jdbcType=VARCHAR},  
  28.                #{fee,jdbcType=NUMERIC},  
  29.                #{accountFirstType,jdbcType=NUMERIC},  
  30.                #{accountSecondType,jdbcType=NUMERIC},  
  31.                #{accountThirdType,jdbcType=NUMERIC},  
  32.                #{logSecondType,jdbcType=NUMERIC},  
  33.                #{logIp,jdbcType=VARCHAR},  
  34.                #{memo,jdbcType=VARCHAR}  
  35.                )  
  36.     </insert>  



這個時候 運行正常。 

我不甘心 想試試 ibatis2 是否也有一樣的問題 

xml以下: 

Xml代碼  收藏代碼

  1. <insert id="BasicUserInfoDaoImpl.testMap" parameterClass="java.util.HashMap">  
  2.                 insert into customer_log  
  3.                 (  
  4.                 ID,  
  5.                 CUSTOMER_SERVICE_USER_NAME,  
  6.                 user_name,  
  7.                 CONTENT,  
  8.                 LOG_FIRST_TYPE,  
  9.                 STATUS,  
  10.                 LINKED_ID,  
  11.                 FEE,  
  12.                 ACCOUNT_FIRST_TYPE,  
  13.                 ACCOUNT_SECOND_TYPE,  
  14.                 ACCOUNT_THIRD_TYPE,  
  15.                 LOG_SECOND_TYPE,  
  16.                 LOG_IP,  
  17.                 MEMO  
  18.                 )  
  19.                 values  
  20.                 (  
  21.                      seq_customer_log.nextval ,  
  22.                       #customerServiceUserName# ,  
  23.                       #username#,  
  24.                       #content#,  
  25.                       #logFirstType#,  
  26.                       #status#,  
  27.                       #linkedId#,  
  28.                       #fee#,  
  29.                       #accountFirstType#,  
  30.                       #accountSecondType#,  
  31.                       #accountThirdType#,  
  32.                       #logSecondType#,  
  33.                       #logIp#,  
  34.                       #memo#  
  35.                 )  
  36.     </insert>  



這個時候 發現 ibatis2 能夠正常的執行 數據庫能夠正常的插入數據 。 
錯誤日誌是在:org.apache.ibatis.type.BaseTypeHandler這個類的第17行打出的。根據異常上面的代碼 

Java代碼  收藏代碼

  1. if (parameter == null) {  
  2.   if (jdbcType == null) {  
  3.   try {  
  4.   ps.setNull(i, JdbcType.OTHER.TYPE_CODE);  
  5.   } catch (SQLException e) {  
  6.   throw new TypeException("Error setting null parameter. Most JDBC drivers require that the JdbcType must be specified for all nullable parameters. Cause: " + e, e);  
  7.   }  
  8.   } else {  
  9.   ps.setNull(i, jdbcType.TYPE_CODE);  
  10.   }  
  11.   } else {  
  12.   setNonNullParameter(ps, i, parameter, jdbcType);  
  13.   }  


能夠看出,是由於你傳入的參數的字段爲null對象沒法獲取對應的jdbcType類型,而報的錯誤。 
你只要在insert語句中insert的對象加上jdbcType就能夠了,修改以下: 
#{menuTitle,jdbcType=VARCHAR} 
這樣就能夠解決以上錯誤了。 
看來須要真正的瞭解mybatis 和ibatis 呀。 
但願遇到一樣問題的朋友一塊兒交流。 


晚上看到了http://wksandy.iteye.com/blog/1443133 感謝 感謝 WKsandy ,他的文字寫得很好 

 

引用

還有在向oracle插入數據時,mybatis3報Error setting null parameter. Most JDBC drivers require that the JdbcType must be specified for all nullable parameters,是因爲參數出現了null值,對於Mybatis,若是進行操做的時候,沒有指定jdbcType類型的參數,mybatis默認jdbcType.OTHER致使,給參數加上jdbcType可解決(注意大小寫) 

相關文章
相關標籤/搜索