Skip to content

1.问题分析

我们在开发中经常遇到多个实体类有共同的属性字段,例如在新增员工时需要设置创建时间、创建人、修改时间、修改人等字段,在编辑员工时需要设置修改时间和修改人等字段。这些字段属于公共字段,也就是很多表中都有这些字段,能不能对于这些公共字段在某个地方统一处理,来简化开发呢?

image-20220725172038979

答案就是使用Mybatis Plus提供的公共字段自动填充功能

2.实现步骤

Mybatis Plus公共字段自动填充,也就是在插入或者更新的时候为指定字段赋予指定的值,使用它的好处就是可以统一对这些字段进行处理,避免了重复代码。

实现步骤:

  • 在实体类的属性上加入@TableField注解,指定自动填充的策略

    @TableField(fill = FieldFill.INSERT)//插入时填充字段
    private LocalDateTime createTime;
     
    @TableField(fill = FieldFill.INSERT_UPDATE)//插入、更新时填充字段
    private LocalDateTime updateTime;
     
    @TableField(fill = FieldFill.INSERT)//插入时填充字段
    private Long createUser;
    
    @TableField(fill = FieldFill.INSERT_UPDATE)//插入、更新时填充字段
    private Long updateUser;
    java
  • 按照框架要求编写元数据对象处理器,在此类中统一为公共字段赋值,此类需要实现MetaObjectHandler接口

    package com.itheima.reggie.common;
    
    import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
    import org.apache.ibatis.reflection.MetaObject;
    import org.springframework.stereotype.Component;
    
    import java.time.LocalDateTime;
    
    /**
     * @Author Vz
     * Created with IntelliJ IDEA.
     * Created on 2022-07-23 17:45
     * Description:元数据对象处理器
     */
    @Component
    public class MyMetaObjectHandler implements MetaObjectHandler {
    
        /**
         * 插入时自动填充
         * @param metaObject
         */
        @Override
        public void insertFill(MetaObject metaObject) {
            metaObject.setValue("createTime", LocalDateTime.now());
            metaObject.setValue("updateTime", LocalDateTime.now());
            metaObject.setValue("createUser",BaseContext.getCurrentId());
            metaObject.setValue("updateUser",BaseContext.getCurrentId());
        }
    
        /**
         * 更新时自动填充
         * @param metaObject
         */
        @Override
        public void updateFill(MetaObject metaObject) {
            metaObject.setValue("updateTime", LocalDateTime.now());
            metaObject.setValue("updateUser",BaseContext.getCurrentId());
        }
    }
    
    java

用心去做高质量的内容网站,欢迎 star ⭐ 让更多人发现