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

Posted Adorable_Rocy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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类型存入到数据库中。

  • 再次请求,完成插入操作。

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

以上是关于Mybatis 中报错:ORA-01861: 文字与格式字符串不匹配的主要内容,如果未能解决你的问题,请参考以下文章

SQL 错误:ORA-01861:文字与格式字符串 01861 不匹配

ORA-01861: 文字与格式字符串不匹配: SQL

php ORA-01861: 文字与格式字符串不匹配

ORA-01861: 在 django 中执行获取模型对象时文字与格式字符串不匹配

Oracle ORA-01861: 文字与格式字符串不匹配

查询 SQL语句的时候 出现oracle ora 01861 文字与字符串格式不匹配 百思不得其解!