需求:平时在做增删改查时,创建人,创建时间,更新人,更新时间,版本号这些字段是都有的,每次都写很麻烦,现在可以通过配置就可以不用管这些字段,写入表时这些字段自动填充
- 依赖
compile 'com.baomidou:mybatis-plus-boot-starter:3.1.1'
<dependency>
<groupId>com.baomidougroupId>
<artifactId>mybatis-plus-boot-starterartifactId>
<version>3.1.1version>
dependency>
- 基础类
@Data
public class BaseEntity {
@TableId(value = "id",type = IdType.AUTO)
public Long id;
@TableField(fill = FieldFill.INSERT)
private String createBy;
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
private String updateBy;
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
@TableField(fill = FieldFill.INSERT, update="%s+1")
private Long version;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 自动填充类
@Component
public class MybatisPlusMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.setFieldValByName("createBy", CookieUtil.getLoginUser(),metaObject);
this.setFieldValByName("createTime", new Date(),metaObject);
this.setFieldValByName("updateBy", CookieUtil.getLoginUser(),metaObject);
this.setFieldValByName("updateTime", new Date(),metaObject);
this.setFieldValByName("version", Long.valueOf(1),metaObject);
this.setFieldValByName("appSecret", UUID.randomUUID().toString().replaceAll("-",""),metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
this.setFieldValByName("updateBy", CookieUtil.getLoginUser(),metaObject);
this.setFieldValByName("updateTime", new Date(),metaObject);
this.setFieldValByName("version", this.getFieldValByName("version",metaObject),metaObject);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
值 | 描述 |
---|
value | 字段值(驼峰命名方式,该值可无) |
update | 预处理 set 字段自定义注入 |
condition | 预处理 WHERE 实体条件自定义运算规则 |
el | 详看注释说明 |
exist | 是否为数据库表字段( 默认 true 存在,false 不存在 ) |
strategy | 字段验证 ( 默认 非 null 判断,查看 com.baomidou.mybatisplus.enums.FieldStrategy ) |
fill | 字段填充标记 ( FieldFill, 配合自动填充使用 ) |
值 | 描述 |
---|
value | 字段值(驼峰命名方式,该值可无) |
update | 预处理 set 字段自定义注入 |
condition | 预处理 WHERE 实体条件自定义运算规则 |
el | 详看注释说明 |
exist | 是否为数据库表字段( 默认 true 存在,false 不存在 ) |
strategy | 字段验证 ( 默认 非 null 判断,查看 com.baomidou.mybatisplus.enums.FieldStrategy ) |
fill | 字段填充标记 ( FieldFill, 配合自动填充使用 ) |