zoukankan      html  css  js  c++  java
  • mybatis 插入空值时报错 TypeException

    报错内容:nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='transferPersitionTime', mode=IN, javaType=class java.lang.Object, jdbcType=null, numericScale=null, resultMapId='null', jdbcTypeName='null', expression='null'}. Cause: org.apache.ibatis.type.TypeException: Error setting null for parameter #9 with JdbcType OTHER . Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. Cause: java.sql.SQLException: 无效的列类型

    之前使用的是mysql,后面转为 oracle ,切换之后插入数据就报错

    插入空值时需要制定类型

    所以我们指定类型就好了

    insert into
    	clean_user(id,status,update_time,mip,emp_name,emp_code,old_unit_code,old_unit_name,new_unit_code,new_unit_name,transfer_persition_time,erp_uid,backup1,backup2,backup3)
    	values(
    	SYS_GUID(),
    	#{status,jdbcType=VARCHAR},
    	#{updateTime,jdbcType=TIMESTAMP},
    	#{mip,jdbcType=VARCHAR},
    	#{empName,jdbcType=VARCHAR},
    	#{empCode,jdbcType=VARCHAR},
    	#{oldUnitCode,jdbcType=VARCHAR},
    	#{oldUnitName,jdbcType=VARCHAR},
    	#{newUnitCode,jdbcType=VARCHAR},
    	#{newUnitName,jdbcType=VARCHAR},
    	#{transferPersitionTime,jdbcType=VARCHAR},
    	#{erpUid,jdbcType=VARCHAR},
    	#{backup1,jdbcType=VARCHAR},
    	#{backup2,jdbcType=VARCHAR},
    	#{backup3,jdbcType=VARCHAR}
    	)
    

      有什么类型呢,查看 org.apache.ibatis.type.JdbcType.java 就可以看到了。

     ARRAY(Types.ARRAY),
      BIT(Types.BIT),
      TINYINT(Types.TINYINT),
      SMALLINT(Types.SMALLINT),
      INTEGER(Types.INTEGER),
      BIGINT(Types.BIGINT),
      FLOAT(Types.FLOAT),
      REAL(Types.REAL),
      DOUBLE(Types.DOUBLE),
      NUMERIC(Types.NUMERIC),
      DECIMAL(Types.DECIMAL),
      CHAR(Types.CHAR),
      VARCHAR(Types.VARCHAR),
      LONGVARCHAR(Types.LONGVARCHAR),
      DATE(Types.DATE),
      TIME(Types.TIME),
      TIMESTAMP(Types.TIMESTAMP),
      BINARY(Types.BINARY),
      VARBINARY(Types.VARBINARY),
      LONGVARBINARY(Types.LONGVARBINARY),
      NULL(Types.NULL),
      OTHER(Types.OTHER),
      BLOB(Types.BLOB),
      CLOB(Types.CLOB),
      BOOLEAN(Types.BOOLEAN),
      CURSOR(-10), // Oracle
      UNDEFINED(Integer.MIN_VALUE + 1000),
      NVARCHAR(Types.NVARCHAR), // JDK6
      NCHAR(Types.NCHAR), // JDK6
      NCLOB(Types.NCLOB), // JDK6
      STRUCT(Types.STRUCT);
    

      

  • 相关阅读:
    批量杀掉多个pid文件中记录的pid进程, 并集成到shell脚本中
    把tomcat服务器配置为windows服务的方法
    idea导入java项目
    linux-umount挂载点无法卸载:device is busy(解决)
    简单(基本)的风光摄影照片后期处理-新手教程-ps照片后期基本处理
    golang 打包,交叉编译,压缩
    mac下Fiddler的安装-启动
    修改ElementUI源码样式
    linux里面的命令:./和. /(这里有空格)的区别
    linux下mysql源码安装
  • 原文地址:https://www.cnblogs.com/yun965861480/p/6906883.html
Copyright © 2011-2022 走看看