公共字段填充

再新增一些数据时,需要默认填充一些动态数据,比如创建账号的时间等,为了简介方便,将此类步骤封装起来,封装到线程中,在一次请求中,自动走到线程中去执行添加及更新公共字段

需使用的技术

  • MyBatisPlus的公共字段自动填充功能,在实体类中找到需要自动填充的字段,使用注解@TableField 及注解中的属性(fill = FieldFill.INSERT/FieldFill.INSERT_UPDATE)
  • MyBatisPlus的一个接口,MetaObjectHandler,实现insertFill和updateFill方法,在其中填写相应的字段填充

问题:

        有一些数据需要在servlet作用域中获取,因此需要使用线程来获取其中的数据

需要用到:

        1). LoginCheckFilter的doFilter方法***过滤器

        2). EmployeeController的update方法***控制层的需要添加或修改的方法

        3). MyMetaObjectHandler的updateFill方法***MyMetaObjectHandler的自动填充方法

@Component
public class FieldMetaHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        metaObject.setValue("createTime", LocalDateTime.now());
        metaObject.setValue("updateTime", LocalDateTime.now());
        metaObject.setValue("createUser", Long.valueOf((String) ThreadLocalSet.getId()));
        metaObject.setValue("updateUser", Long.valueOf((String) ThreadLocalSet.getId()));
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        metaObject.setValue("updateTime", LocalDateTime.now());
        metaObject.setValue("updateUser", Long.valueOf((String) ThreadLocalSet.getId()));
    }
}

 

ThreadLocal

        A. public void set(T value) : 设置当前线程的线程局部变量的值

        B. public T get() : 返回当前线程所对应的线程局部变量的值

        C. public void remove() : 删除当前线程所对应的线程局部变量的值

public class ThreadLocalSet{

    private static ThreadLocal<Object> threadLocal = new ThreadLocal<Object>();

    public static Object getId(){
        return threadLocal.get();
    }

    public static void setId(Object id){
        threadLocal.set(id);
    }

}

总结

  • 先把自动填充功能写完
  • 再创建工具类,基于ThreadLocal,获取存储于作用域中的数据
  • 在过滤器中调用工具类的方法,设置数据
  • 在MyMetaObjectHandler类中调用工具类的方法,获取数据

### MyBatis 中实现公共字段自动填充 在传统 MyBatis 开发中,为了实现在每次插入或更新记录时自动设置某些公共字段(如 `create_time` 和 `update_time`),通常需要手动编写 SQL 或者借助拦截器来完成这一操作。然而,在引入 MyBatis-Plus 后,可以更加便捷地通过内置机制实现这些需求。 #### 使用 MyBatis-Plus 自动填充功能 MyBatis-Plus 提供了一种简单的方式来处理实体类中的时间戳和其他通用属性的自动化管理。具体来说: - **定义实体类**:首先应当确保实体对象中有对应的字段用于存储创建时间和修改时间,并标记相应的注解以便框架识别[^1]。 ```java import com.baomidou.mybatisplus.annotation.TableField; import java.util.Date; public class User { private Long id; @TableField(fill = FieldFill.INSERT) private Date createTime; // 创建时间 @TableField(fill = FieldFill.UPDATE) private Date updateTime; // 更新时间 } ``` - **配置处理器**:接着需注册一个元数据对象处理器 (`MetaObjectHandler`) 来指定具体的逻辑,比如当前日期作为默认值填入上述两个字段内。 ```java import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; import java.util.Date; @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObj) { this.strictInsertFill(metaObj, "createTime", Date.class, new Date()); } @Override public void updateFill(MetaObject metaObj) { this.strictUpdateFill(metaObj, "updateTime", Date.class, new Date()); } } ``` - **项目配置文件调整**:对于基于 Spring Boot 的应用而言,还需要适当调整 application.yml 文件以支持数据库连接及其他必要的参数设定[^2]。 ```yaml server: port: 8081 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&serverTimezone=GMT%2B8 username: root password: yourpasswordhere ``` 以上步骤完成后,每当执行新增或编辑操作时,MyBatis-Plus 将会依据所定义的行为自动为相应的时间戳字段赋值,从而简化开发流程并减少潜在错误的发生几率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值