MyBatis操作Oracle,参数值为Null的问题

问题描述

使用Mybatis操作Oracle数据库时,当传入的参数值为NULL时,程序执行会中断报错,提示 “无效字符:1111”的字样;

解决办法(x2)

  1. 为参数指定一个数据类型(参考)
#{property,javaType=int,jdbcType=NULL}

通常javaType 通常可以由参数对象确定,如果无法确定参数类型,
例如HashMap 的Value就应该明确指明 javaType。

  1. 在Mybatis配置文件...中添加设置 : jdbcTypeForNull(参考)

            

jdbcTypeForNull ,当没有为参数提供特定的 JDBC 类型时,为空值指定 JDBC 类型。默认值为OTHER ,当需要插入空值时设置为NULL

熄灯

1、 如果一个列允许 null 值,并且会传递值 null 的参数,就必须要指定 JDBC Type。

2、Mybatis insert空值报空值异常,但是在pl/sql不会提示错误,主要原因是mybatis无法进行转换。

你可能感兴趣的:(开发随笔)