在项目中使用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.youkuaiyun.com/loongshawn/article/details/50496460