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

问题描述

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

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

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

  1. 在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无法进行转换。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小技工丨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值