mybatis 为什么要设置jdbcType

mybatis 为什么要设置jdbcType以前没注意过这个问题,用ibatis的时候从来没有设置过jdbcType。ibatis也不会出现这个问题。学习了——————————————————————————————————————————————转载自:http://makemyownlife.iteye.com/blog/1610021前天遇到一个问题异常显示如下: 引用Exceptioninthr

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

以前没注意过这个问题,用ibatis的时候从来没有设置过jdbcType。ibatis也不会出现这个问题。学习了

——————————————————————————————————————————————

转载自: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如下: 

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



可以看出,是因为你传入的参数的字段为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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179874.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • oracle关闭服务命令_oracle数据库命令

    oracle关闭服务命令_oracle数据库命令一、srvctl命令的使用srvctl是servicecontrol的缩写,基本的用法是srvctl[],使用srvctl命令,可以对rac各个节点的数据库实例,asm实例和监听器等进行管理,挺方便的工具oracle@rac2~]$srvctlUsage:srvctl[]command:enable|disable|start|stop|relocate|status|add…

    2022年9月12日
    0
  • 新手小白学JAVA 面向对象之多态

    新手小白学JAVA 面向对象之多态4多态4.1概念多态指同一个实体同时具有多种形式它是面向对象程序设计(OOP)的一个重要特征。主要是指同一个对象,在不同时刻,代表的对象不一样,指的是对象的多种形态。好处是:可以把不同的子类对象都当作父类来看,可以屏蔽不同子类对象之间的差异,写出通用的代码,做出通用的编程,统一调用标准。水果有两种形态:水果和苹果,不关心买回来的是苹果还是西瓜,只要是水果就行classAnimal{//1.定义父类Animal…eat(){syso(“吃啥都行”)}}classCatexte

    2022年7月19日
    11
  • mysql中kill掉所有锁表的进程

    mysql中kill掉所有锁表的进程很多时候由于异常或程序错误会导致个别进程占用大量系统资源,需要结束这些进程,通常可以使用以下命令Kill进程:mysql中kill掉所有锁表的进程2009-05-1214:03转载请保留如下作者信息作者:jesse博客:http://hi.baidu.com/leechl3点钟刚睡下,4点多,同事打电话告诉我用户数据库挂

    2022年8月23日
    4
  • matlab最优化问题的函数(fminbnd),fmincon,globalsearch,multistart(全局局部最优)

    matlab最优化问题的函数(fminbnd),fmincon,globalsearch,multistart(全局局部最优)在讨论优化问题时我们先来讨论全局最优和局部最优全局最优:问题所有的可能解中效果最好的解。局部最优:问题的部分可能解中效果最好的解。一个针对的全局,一个针对的部分。就像我们设初值一样,设置了以后函数开始迭代变化。这时可能出现两种现象①迭代到一个解,该解距离初值较近,此处该值很有可能是局部最优。②迭代到一个解,该解距离初值相对较远,此处该值很大可能是全局最优,当然也可能是局部最优。上…

    2022年5月8日
    301
  • Response.ContentType 网页输出word excel 的格式

    Response.ContentType 网页输出word excel 的格式不同的ContentType会影响客户端所看到的效果.默认的ContentType为text/html也就是网页格式.代码如:显示的为网页,而则会显示html原代码.以下为一些常用的ContentTypeGIFimagesJPEGimagesTIFFimagesMICROSOFTWORDdocument

    2022年7月19日
    57
  • bool函数使用「建议收藏」

    bool函数使用「建议收藏」bool函数的使用

    2022年6月13日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号