mybatis 设置字段值为null 不生效不起作用 解决办法
问题
updateObj.setPublishTime(null);int update = protocolMapper.updateById(updateObj);
执行之后,不生效,数据库里仍有值
解决
在需要设置null的字段加上 @TableField(updateStrategy = FieldStrategy.IGNORED)
/*** 协议管理 DO*/
@TableName("system_protocol")
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ProtocolDO extends BaseDO {/*** 主键*/@TableIdprivate Long id;/*** 发布时间*添加注解放行*/@TableField(updateStrategy = FieldStrategy.IGNORED)private Date publishTime;}
策略其他枚举
package com.baomidou.mybatisplus.annotation;/*** 字段策略枚举类* <p>* 如果字段是基本数据类型则最终效果等同于 {@link #ALWAYS}** @author hubin* @since 2016-09-09*/
public enum FieldStrategy {/*** 忽略判断** @deprecated 3.5.3.2 该字段存在语义理解问题效果等于{@link #ALWAYS}*/@DeprecatedIGNORED,/*** 任何时候都加入 SQL*/ALWAYS,/*** 非NULL判断*/NOT_NULL,/*** 非空判断(只对字符串类型字段,其他类型字段依然为非NULL判断)*/NOT_EMPTY,/*** 默认的,一般只用于注解里* <p>1. 在全局里代表 NOT_NULL</p>* <p>2. 在注解里代表 跟随全局</p>*/DEFAULT,/*** 不加入 SQL*/NEVER
}