Mybatis 中报错:ORA-01861: 文字与格式字符串不匹配

报错如下:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='TYPENAME', 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 #7 with JdbcType OTHER . Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. Cause: java.sql.SQLException: 无效的列类型: 1111
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:77)
	at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:446)
	at com.sun.proxy.$Proxy64.insert(Unknown Source)
	at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:278)
	at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:58)
	at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:59)
	at com.sun.proxy.$Proxy71.insertDictionary(Unknown Source)
  • 查阅了一些资料,网上很多都说是传入了null的原因,经过亲测,验证结果:并不是这个原因,并且抛出了以下错误(纠正一下哈,这里能否传入null跟数据表结构设计有关,是可以传入null的
    在这里插入图片描述
  • 但是明明数据都正确了,为什么还是报了这个错误?唯一不同的点就是在时间处理上面,于是就能找到这个不匹配是因为时间不正确导致的,追寻到时间这一栏

在这里插入图片描述
补充:oracle使用TO_DATE方法要注意,参数参入的是是对应格式的日期转换,例如DATE是指包含年月日的,没有精确到十分秒(2021-08-03)这样的时间日期,类型是String类型的,但是会通过函数转换成DATE类型存入到数据库中。

  • 再次请求,完成插入操作。
    在这里插入图片描述

  • 其实就是要规范传参啦,要规范约定好,就能避免这些错误了(不规范自检,还原之前犯下的错误!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值