zoukankan      html  css  js  c++  java
  • 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代码  收藏代码
    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

    转自:http://makemyownlife.iteye.com/blog/1610021 感谢作者

  • 相关阅读:
    题目1202:排序------注意每个数字的后面都有空格
    题目1178:复数集合------------结构体的的比较,cmp()函数的错误让我WA了多次
    题目1041:Simple Sorting-------注意最后一个数字的处理
    题目1034:寻找大富翁---用了sort()函数,注意头文件;
    题目1415:不一样的循环队列------注意细节小地方循环队列注意%M;还有为什么M要加一!!!!!!!!!!!!!
    题目1342:寻找最长合法括号序列II---注意:不要求就近匹配,只要求( 在 )前面的任一个位置即可
    题目1398:移动次数-----最少移动的次数,那么相同的最大值越靠后越好,相同的最小值越靠前越好
    题目1375:陈博的完美主义(25分)----------------题目中对输入数字的长度有要求,所以输入字符串,用atoi()转换函数
    题目1363:欢乐斗地主------用数组计数的应用,注意1和2得排在最后,表示最大
    题目1174:查找第K小数-------qsort()可以直接对数组用;还有用unique(a,a+n);的,服!
  • 原文地址:https://www.cnblogs.com/panxuejun/p/6163779.html
Copyright © 2011-2022 走看看