ORACLE数据库结合MyBatis-Plus3.X更新null值失败解决方案

在项目中使用oralce11g以及MyBatis-Plus3.3.0版本,由于MyBatis-Plus的更新表数据的机制默认采用的是忽略空值,即java bean某个属性映射的字段值为空,则update语句中不会出现该字段。看了官方文档,提到三种解决方案:

方案一:更改全局策略是个大坑,万一前端传过来的属性相比新增时有遗漏,则会数据丢失;

方案二:3.0以上版本中将strategy去掉,新增了insertStrategy以及updateStrategy,显然官方文档更新不及时,实测在bean字段上注解@TableField(value="AGE", updateStrategy=FieldStrategr.IGNORE),会报错,控制台显示:无效的列类型:111;

方案三:需要针对项目中所有需要更新NULL值的位置编写个性化方法,过于臃肿及繁琐,因此不考虑。

因此个人最推荐第二种方案,第二种方案产生报错的问题是,没有指定字段类型,那咱们就指定字段类型,例如:

@TableField(value = "AGE", jdbcType = JdbcType.DOUBLE, updateStrategy = FieldStrategy.IGNORED)
private Long age;

另,可参考Mybatis JdbcType与Oracle、MySql数据类型对应列表链接,转自@loongshawn,https://blog.csdn.net/loongshawn/article/details/50496460

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值