问题描述
使用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无法进行转换。