mybatis 需要注意的点 MyBatis 插入空值时,需要指定JdbcType

mybatis 需要注意的点 MyBatis 插入空值时,需要指定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代码   
  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改为:
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如下:
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.   }  
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 呀。
希望遇到同样问题的朋友一起交流。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值