MybatisPlus 字段更新策略 FieldStrategy使用
由于Mybatis plus默认的更新策略是NOT_NULL:非
NULL;即通过接口更新数据时数据为NULL值时将不更新进数据库。所以Mybatis
plus通过updateById(XXX)更新数据,当用户有更新字段为 空字符串 或者 null 的需求时,需要对
FieldStrategy 策略进行调整。
使某个字段生效,传空更新成空
方式一
缺点:这样做会对所有的字段都忽略判断,如果一些字段不想要修改,但是传值的时候没有传递过来,就会被更新为null
@ApiModelProperty(value = "权重")
@TableField(updateStrategy = FieldStrategy.IGNORED)
private Integer priority;
方式二
mybatis-plus:
global-config:
#字段策略 0:"忽略判断",1:"非 NULL 判断",2:"非空判断"
field-strategy: 0
mybatisplus默认更新策略是不更新空值的
public enum FieldStrategy {
/**
* 忽略判断
*/
IGNORED,
/**
* 非NULL判断
*/
NOT_NULL,
/**
* 非空判断(只对字符串类型字段,其他类型字段依然为非NULL判断)
*/
NOT_EMPTY,
/**
* 默认的,一般只用于注解里
* <p>1. 在全局里代表 NOT_NULL</p>
* <p>2. 在注解里代表 跟随全局</p>
*/
DEFAULT,
/**
* 不加入 SQL
*/
NEVER
}
/
更新数据和主键生成策略
/weixin_45301250/article/details/118863651