Mybatis-Plus中调用updateById方法,进行数据更新默认情况下是不能更新空值字段的。
而在实际开发过程中,往往会遇到需要将字段值更新为空值的情况。
那么如果让Mybatis-Plus中的updateById方法支持空值更新呢?
Mybatis-Plus中字段的更新策略是通过FieldStrategy属性控制的。
在实体字段上,如果不通过@TableField注解指定字段的更新策略,字段默认的更新策略是FieldStrategy.DEFAULT,即跟随全局策略。
而Mybatis-Plus的全局配置中,字段的默认更新策略是FieldStrategy.NOT_NULL,即进行空值判断,不对NULL值数据进行处理。
1、设置字段级别的更新策略IGNORED
如果只需要实体中的几个字段支持空值更新,则通过@TableField注解指定字段的更新策略为FieldStrategy.IGNORED,忽略空值判断,直接更新即可。该方式的控制级别是字段级别的控制。
2、设置全局更新策略IGNORED
如果需要全局所有实体的更新操作都需要支持空值更新,可以修改Mybatis-Plus的全局更新策略。
该方式的控制级别是项目级别的控制。
在spring boot中修改如下属性即可:
mybatis-plus.global-config.db-config.update-strategy=ignored