MYBATIS 插入空值时报错 Could not set parameters for mapping: ParameterMapping{property=‘addressList‘, mode=

报错内容: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);

参考:

https://www.cnblogs.com/yun965861480/p/6906883.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值