转载自:http://makemyownlife.iteye.com/blog/1610021

前天遇到一个问题 异常显示如下:

引用
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如下:

  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>

查询了一下 一些资料说是:

引用
MyBatis 插入空值时,需要指定JdbcType 
mybatis insert空值报空值异常,但是在pl/sql不会提示错误,主要原因是mybatis无法进行转换, 

所以将xml改为:

  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如下:

  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行打出的。根据异常上面的代码

  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可解决(注意大小写)

http://code.google.com/p/mybatis/issues/detail?id=224&q=Error%20setting%20null%20parameter&colspec=ID

mybatis 为什么要设置jdbcType的更多相关文章

  1. 记自己在mybatis中设置jdbcType的一个坑

    项目是用ssm搭建的.主要是为app数据接口.其中有一个需求就app想要查询一段时间内某个用户的测量信息,所以app给我后端传递了3个参数,分别是appuserId(String),startDate ...

  2. mybatis插入语句空值没有设置jdbcType报错

    Exception in thread "main" org.springframework.jdbc.UncategorizedSQLException: Error setti ...

  3. 161115、MyBatis 通过包含的jdbcType类型

    MyBatis常用jdbcType类型 BIT         FLOAT      CHAR           TIMESTAMP       OTHER       UNDEFINEDTINYI ...

  4. MyBatis 通过包含的jdbcType类型和java中对应的数据类型

    MyBatis 通过包含的jdbcType类型 BIT         FLOAT      CHAR           TIMESTAMP       OTHER       UNDEFINED ...

  5. Mybatis使用- Mybatis JdbcType与Oracle、MySql数据类型对应列表 ; Mybatis中javaType和jdbcType对应关系

    Mybatis JdbcType与Oracle.MySql数据类型对应列表  Mybatis JdbcType Oracle MySql JdbcType ARRAY     JdbcType BIG ...

  6. (转)MyBatis在插入的数据有空值时,可能为空的字段都要设置jdbcType

    1 引言 前面的所有语句中你所见到的都是简单参数的例子,实际上参数是 MyBatis 非常强大的元素,对于简单的做法, 90% 的情况参数都很少,比如: <select id="sel ...

  7. MyBatis的settings设置描述

    settings 中的设置是非常关键的,它们会改变 MyBatis 的运行时行为.下表描述了设置中各项的意图.默认值等. 设置参数 描述 有效值 默认值 cacheEnabled 该配置影响的所有映射 ...

  8. MyBatis与Spring设置callSettersOnNulls

    项目中集成Mybatis与Spring,使用的是Mybatis3.2.7,以及Spring4.0.5,mybatis-spring-1.2.2;由于项目组成员想要偷懒,将数据从DB中查询出来时须要将字 ...

  9. SpringBoot与Mybatis整合的设置

    Mybatis和Spring Boot的整合有两种方式: 第一种:使用mybatis官方提供的Spring Boot整合包实现,地址:https://github.com/mybatis/spring ...

随机推荐

  1. Android 7.0解决抓取不到https请求的问题

    问题:Android7.0系统,使用fiddler不能抓取https请求 解决方法:  1.在源码res目录下新建xml目录,增加network_security_config.xml文件 (工程名/ ...

  2. 如何搭建python+selenium2+eclipse的环境

    搭建python和selenium2的环境(windows) 1.下载并安装python(我用的是2.7的版本) 可以去python官网下载安装:http://www.python.org/getit ...

  3. poj3292(筛法+打表)

    题目链接:https://vjudge.net/problem/POJ-3292 题意:定义4n+1数(简称H数),H数分为三类:unit,即为1; H-primes,只能分解为1×自身,类似于我们平 ...

  4. hdoj1005(循环,找规律)

    Problem Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1 ...

  5. JS 解决json字符串转换成json树形输出

    问题: 后台获取一个字符串,格式为  string +jsonList+string+..... 就是传过来一堆数据,然后其中包含了一个json格式的list, 我们希望能将它输出成树形结构显示,能够 ...

  6. unity美少女动作RPG游戏源码Action-RPG Starter Kit v5.0a

    功能完整的ARPG游戏模板 Core Features!! - Combat System - Skill Tree - Enemy AI - Save-Load Game - Shop System ...

  7. javascript简单的滑动效果

    利用setInterval实现简单的滑动效果 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  8. mysql之 安装(Mac)

    1.官网下载安装包:https://dev.mysql.com/downloads/mysql/ 2.设置环境变量:(1)首先mysql的安装位置为:/usr/local/mysql/bin (2)在 ...

  9. JS 获取屏幕的宽度和高度,各种方式

      Javascript: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: document ...

  10. JsRender 学习总结

    jsRender 三个最重要的概念:模板.容器和数据. 最重要的是:view(视图) 是我们定义的模板,上下文是视图所用的对象. 一.基础. {{:}} 和 {{>}}(或{{html:}})两 ...