springboot~MyBatisPlus中使用@TableField完成字段自動填充
字段注解 @TableField中的參數fill
com.baomidou.mybatisplus.annotations.TableField
-
exist
是否為數據庫表字段( 默認 true 存在,false 不存在 ) -
strategy
字段驗證 ( 默認 非 null 判斷,查看 com.baomidou.mybatisplus.enums.FieldStrategy ) -
fill
字段填充標記 ( FieldFill, 配合自動填充使用 )
字段填充策略 FieldFill
DEFAULT 默認不處理
INSERT 插入填充字段
UPDATE 更新填充字段
INSERT_UPDATE 插入和更新填充字段
使用
@Data
@EqualsAndHashCode(callSuper=false)
@TableName("sys_user")
public class SysUserEntity extends BaseEntity {
private static final long serialVersionUID = 1L;
/**
* 用戶名
*/
private String username;
/**
* 密碼
*/
private String password;
/**
* 創建者
*/
@TableField(fill = FieldFill.INSERT)
private Long creator;
/**
* 創建時間
*/
@TableField(fill = FieldFill.INSERT)
private Date createDate;
/**
* 更新者
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Long updater;
/**
* 更新時間
*/
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateDate;
}
添加hander對它進行處理
/**
* 公共字段,自動填充值
*
* @author Mark sunlightcs@gmail.com
*/
@Component
public class FieldMetaObjectHandler implements MetaObjectHandler {
private final static String CREATE_DATE = "createDate";
private final static String CREATOR = "creator";
private final static String UPDATE_DATE = "updateDate";
private final static String UPDATER = "updater";
@Override
public void insertFill(MetaObject metaObject) {
UserDetail user = SecurityUser.getUser();
Date date = new Date();
//創建者
strictInsertFill(metaObject, CREATOR, Long.class, user.getId());
//創建時間
strictInsertFill(metaObject, CREATE_DATE, Date.class, date);
//更新者
strictInsertFill(metaObject, UPDATER, Long.class, user.getId());
//更新時間
strictInsertFill(metaObject, UPDATE_DATE, Date.class, date);
}
@Override
public void updateFill(MetaObject metaObject) {
//更新者
strictUpdateFill(metaObject, UPDATER, Long.class, SecurityUser.getUserId());
//更新時間
strictUpdateFill(metaObject, UPDATE_DATE, Date.class, new Date());
}
當然,我們自己寫攔截器,去攔截mybatis最終的insert,update方法也是可以實現相同的功能的。
浙公網安備 33010602011771號