1.方法一 (可以更新任何字段)
注意:MyMetaObjectHandler.java中更新的字段对应的实体类属性必须使用@TableField(value = "create_date", fill = FieldFill.INSERT) 注解, fill = FieldFill.INSERT代表insert操作时自动填充值
import com.项目用户实体.SysUser;
import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.time.LocalDateTime;
import java.util.Objects;
/**
* insert + update 自动填充公共值
*/
@Configuration //使用@Component无效
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
//fillStrategy填充策略,默认有值不覆盖,如果提供的值为null也不填充
this.fillStrategy(metaObject, "createDate", LocalDateTime.now());
this.fillStrategy(metaObject, "createBy", getUserName());
}
@Override
public void updateFill(MetaObject metaObject) {
this.fillStrategy(metaObject, "updateBy", getUserName());
}
//获取当前用户信息
public String getUserName(){
//获取到当前线程绑定的请求对象
HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
//已经拿到session,就可以拿到session中保存的用户信息了。
SysUser user = (SysUser) request.getSession().getAttribute("user");
if(null == user || StringUtils.isBlank(user.getUserName())){
return "admin";
}
return user.getUserName();
}
}
1.方法二 (只能在update时才能自动更新值)
以下CommonEntity .java是我项目中实体都会继承的基类,
其中@TableField(value = "update_date", fill = FieldFill.UPDATE, update = "now()") // 当执行更新操作时update_date字段会自动设置值为now()
但也只是update操作时会自动填充,其他操作则无效,其他操作只能使用方法一
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.TableField;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
@Data
public class CommonEntity {
@TableField(value = "create_by", fill = FieldFill.INSERT) //insert无值时配合MyMetaObjectHandler类自动生成
private String createBy;
@TableField(value = "create_date", fill = FieldFill.INSERT) //新增时MyMetaObjectHandler类自动设置值
@DateTimeFormat(pattern = "yyyy-MM-dd")//解决前端String日期传到前台Date日期报错的问题,date传到前台展示时自动转成String
@JsonFormat(pattern="yyyy/MM/dd", timezone="GMT+12") //解决日期传到前台少 一天的问题
private LocalDateTime createDate; //已开启自动驼峰, 所以不能写成createDate, 否则自动生成的sql就会去找create_Date
@TableField(value = "update_by", fill = FieldFill.UPDATE) //UPDATE无值时配合MyMetaObjectHandler类自动生成
private String updateBy;
@DateTimeFormat(pattern = "yyyy-MM-dd")//解决前端String日期传到前台Date日期报错的问题,date传到前台展示时自动转成String
@JsonFormat(pattern="yyyy/MM/dd", timezone="GMT+12") //解决日期传到前台少 一天的问题
@TableField(value = "update_date", fill = FieldFill.UPDATE, update = "now()") // 更新时自动设置值为now()
private LocalDateTime updateDate;