Mybatis中的jdbcType的作用

Stella981
• 阅读 611

Mybatis中的jdbcType的作用

使用MyBatis框架做更新操作时,在该字段需要更新的内容为空时,就会出现1111错误,也就是无效的列类型,这个时候你就要使用jdbcType。至于什么时候要使用到javaType我还没遇到过,而且我也没有听说过要使用javaType。

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

引用

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的作用

  1.   
  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.   

  

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

引用

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

所以将xml改为: 

Xml代码  Mybatis中的jdbcType的作用

  1.   
  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.     

  

这个时候 运行正常。 

我不甘心 想试试 ibatis2 是否也有同样的问题 

xml如下: 

Xml代码  Mybatis中的jdbcType的作用

  1.   
  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.     

  

这个时候 发现 ibatis2 可以正常的执行 数据库可以正常的插入数据 。 
错误日志是在:org.apache.ibatis.type.BaseTypeHandler这个类的第17行打出的。根据异常上面的代码 

Java代码  Mybatis中的jdbcType的作用

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

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
2个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这