问题描述
使用Mybatis操作Oracle数据库时,当传入的参数值为NULL时,程序执行会中断报错,提示 “无效字符:1111”的字样;
解决办法(x2)
- 为参数指定一个数据类型(参考)
#{property,javaType=int,jdbcType=NULL}
通常javaType 通常可以由参数对象确定,如果无法确定参数类型,
例如HashMap<String,Object>的Value就应该明确指明 javaType。
- 在Mybatis配置文件
<settings>...</settings>中添加设置 :jdbcTypeForNull(参考)
<settings>
<setting name="jdbcTypeForNull" value="NULL" />
</settings>
jdbcTypeForNull,当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。默认值为OTHER,当需要插入空值时设置为NULL。
熄灯
1、 如果一个列允许 null 值,并且会传递值 null 的参数,就必须要指定 JDBC Type。
2、Mybatis insert空值报空值异常,但是在pl/sql不会提示错误,主要原因是mybatis无法进行转换。
在使用Mybatis操作Oracle数据库时,遇到传入参数值为NULL导致的“无效字符:1111”错误。本文介绍了解决方案,包括为参数指定数据类型和在配置文件中设置jdbcTypeForNull。
1031

被折叠的 条评论
为什么被折叠?



