MybatisPlus 字段更新策略 FieldStrategy使用

时间:2025-02-14 22:08:05

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