Mybatis中的jdbcType的作用
阿新 • • 發佈:2019-01-11
前天遇到一個問題 異常顯示如下:
引用
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
對應的sqlmap如下:
Xml程式碼
查詢了一下 一些資料說是:
引用
MyBatis 插入空值時,需要指定JdbcType
mybatis insert空值報空值異常,但是在pl/sql不會提示錯誤,主要原因是mybatis無法進行轉換,
所以將xml改為:
Xml程式碼
這個時候 執行正常。
我不甘心 想試試 ibatis2 是否也有同樣的問題
xml如下:
Xml程式碼
這個時候 發現 ibatis2 可以正常的執行 資料庫可以正常的插入資料 。
錯誤日誌是在:org.apache.ibatis.type.BaseTypeHandler這個類的第17行打出的。根據異常上面的程式碼
Java程式碼
可以看出,是因為你傳入的引數的欄位為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可解決(注意大小寫)
引用
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
對應的sqlmap如下:
Xml程式碼
- <insert id="insertCustomerLog" parameterType="map">
- insert into customer_log
- (
- ID,
- CUSTOMER_SERVICE_USER_NAME,
- user_name,
- CONTENT,
- LOG_FIRST_TYPE,
- STATUS,
- LINKED_ID,
- FEE,
- ACCOUNT_FIRST_TYPE,
-
ACCOUNT_SECOND_TYPE,
- ACCOUNT_THIRD_TYPE,
- LOG_SECOND_TYPE,
- LOG_IP,
- MEMO
- )
- values
- (
- seq_customer_log.nextval ,
- #{customerServiceUserName} ,
- #{username},
- #{content},
- #{logFirstType},
-
#{status},
- #{linkedId},
- #{fee},
- #{accountFirstType},
- #{accountSecondType},
- #{accountThirdType},
- #{logSecondType},
- #{logIp},
- #{memo}
- )
- </insert>
查詢了一下 一些資料說是:
引用
MyBatis 插入空值時,需要指定JdbcType
mybatis insert空值報空值異常,但是在pl/sql不會提示錯誤,主要原因是mybatis無法進行轉換,
所以將xml改為:
Xml程式碼
- <insert id="insertCustomerLog1" parameterType="com.diyicai.customer.domain.CustomerLog">
- insert into customer_log
- (
- ID,
- CUSTOMER_SERVICE_USER_NAME,
- user_name ,
- CONTENT,
- LOG_FIRST_TYPE,
- STATUS,
- LINKED_ID,
- FEE,
- ACCOUNT_FIRST_TYPE,
- ACCOUNT_SECOND_TYPE,
- ACCOUNT_THIRD_TYPE,
- LOG_SECOND_TYPE,
- LOG_IP,
- MEMO
- )
- values
- (
- seq_customer_log.nextval ,
- #{customerServiceUserName,jdbcType=VARCHAR} ,
- #{username,jdbcType=VARCHAR},
- #{content,jdbcType=VARCHAR},
- #{logFirstType,jdbcType=NUMERIC},
- #{status,jdbcType=NUMERIC},
- #{linkedId,jdbcType=VARCHAR},
- #{fee,jdbcType=NUMERIC},
- #{accountFirstType,jdbcType=NUMERIC},
- #{accountSecondType,jdbcType=NUMERIC},
- #{accountThirdType,jdbcType=NUMERIC},
- #{logSecondType,jdbcType=NUMERIC},
- #{logIp,jdbcType=VARCHAR},
- #{memo,jdbcType=VARCHAR}
- )
- </insert>
這個時候 執行正常。
我不甘心 想試試 ibatis2 是否也有同樣的問題
xml如下:
Xml程式碼
- <insert id="BasicUserInfoDaoImpl.testMap" parameterClass="java.util.HashMap">
- insert into customer_log
- (
- ID,
- CUSTOMER_SERVICE_USER_NAME,
- user_name,
- CONTENT,
- LOG_FIRST_TYPE,
- STATUS,
- LINKED_ID,
- FEE,
- ACCOUNT_FIRST_TYPE,
- ACCOUNT_SECOND_TYPE,
- ACCOUNT_THIRD_TYPE,
- LOG_SECOND_TYPE,
- LOG_IP,
- MEMO
- )
- values
- (
- seq_customer_log.nextval ,
- #customerServiceUserName# ,
- #username#,
- #content#,
- #logFirstType#,
- #status#,
- #linkedId#,
- #fee#,
- #accountFirstType#,
- #accountSecondType#,
- #accountThirdType#,
- #logSecondType#,
- #logIp#,
- #memo#
- )
- </insert>
這個時候 發現 ibatis2 可以正常的執行 資料庫可以正常的插入資料 。
錯誤日誌是在:org.apache.ibatis.type.BaseTypeHandler這個類的第17行打出的。根據異常上面的程式碼
Java程式碼
- if (parameter == null) {
- if (jdbcType == null) {
- try {
- ps.setNull(i, JdbcType.OTHER.TYPE_CODE);
- } catch (SQLException e) {
- throw new TypeException("Error setting null parameter. Most JDBC drivers require that the JdbcType must be specified for all nullable parameters. Cause: " + e, e);
- }
- } else {
- ps.setNull(i, jdbcType.TYPE_CODE);
- }
- } else {
- setNonNullParameter(ps, i, parameter, jdbcType);
- }
可以看出,是因為你傳入的引數的欄位為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可解決(注意大小寫)
http://code.google.com/p/mybatis/issues/detail?id=224&q=Error%20setting%20null%20parameter&colspec=ID
轉自:http://makemyownlife.iteye.com/blog/1610021