我是靠谱客的博主 无聊草莓,这篇文章主要介绍MyBatis向Oracle数据库插入NULL数据报错,现在分享给大家,希望可以做个参考。

原文链接

https://blog.wanvale.com/archives/86/

摘要

报错内容如下:

org.springframework.jdbc.UncategorizedSQLException:Error setting null for parameter #6 with JdbcType OTHER . Try setting adifferent JdbcType for this parameter or a different jdbcTypeForNullconfiguration property.

问题分析

有兴趣的同学可以去读一下MyBatis的源码,在JdbcType.class里面定义了原生Jdbc的数据类型,里面定义了一个OTHER(Types.OTHER)。
所以MyBatis对所有null值的映射都为Jdbc OTHER
而对于Oracle数据库来说,是没办法处理OTHER类型的(MySQL中是可以正常插入的,因为MySQL比较遵循规范)

解决方法

方法1

一种解决方法是对数据变量设置jdbcType
TestMapper.xml

复制代码
1
2
3
4
<insert id="..." parameterType="..."> INSERT INTO mybatis_test_01(id,name,remarks) VALUES(SEQ_TEST.nextval, #{name,jdbcType=VARCHAR}, #{remarks,jdbcType=VARCHAR) </insert>

当然,这种方法的弊端是要增加大量代码,提高了后期维护的难度。

方法2

这种方法很简单,修改mybatis-config.xml,添加一行setting就可以了

复制代码
1
2
<setting name="jdbcTypeForNull" value="NULL" />

把上面的一行添加到mybatis配置文件的标签内就可以为null指定jdbc类型了。

文档的描述如下:

当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。 某些驱动需要指定列的 JDBC 类型,多数情况直接用一般类型即可,比如 NULL、VARCHAR 或 OTHER。

至此,问题解决

最后

以上就是无聊草莓最近收集整理的关于MyBatis向Oracle数据库插入NULL数据报错的全部内容,更多相关MyBatis向Oracle数据库插入NULL数据报错内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(118)

评论列表共有 0 条评论

立即
投稿
返回
顶部