二.MyBatis-plus的自动填充数据

二 MyBatis-Plus的自动填充
1.以数据库表中的字段举例,因为创建时间、修改时间!这些个操作一遍都是自动化完成的,我们不希望手动更新!

阿里巴巴开发手册:所有的数据库表:gmt_create、gmt_modifified几乎所有的表都要配置上!而且需

要自动化!

换成通俗易懂的就是createTime和updateTime

2.在数据库中新增字段createTime和updateTime,使用datetime属性

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Yk07fBQ4-1594746815596)(C:\Users\asus\AppData\Roaming\Typora\typora-user-images\1594746379174.png)]

3.在实体层上增加这两个实体类
@TableField(fill = FieldFill.INSERT)
    private Date createTime;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;

注意:1.字段必须声明TableField注解,属性fill选择对应策略,该声明告知Mybatis-Plus需要预留注入SQL字段

​ 2.要想根据注解FieldFill.xxx字段名以及字段类型来区分必须使用父类的strictInsertFill或者strictUpdateFill方法

下面是具体的源码

public enum FieldFill {
    /**
     * 默认不处理
     */
    DEFAULT,
    /**
     * 插入填充字段
     */
    INSERT,
    /**
     * 更新填充字段
     */
    UPDATE,
    /**
     * 插入和更新填充字段
     */
    INSERT_UPDATE
}
4.配置
@Slf4j
@Component
public class MyBatisplusConfig implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill ....");
        this.setFieldValByName("createTime",new Date(),metaObject);
        this.setFieldValByName("updateTime",new Date(),metaObject);

    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime",new Date(),metaObject);

    }

注意 : 1. 需要继承MetaObjectHandler,实现其中的两个方法,插入填充还有修改填充

  1. createTime是你pojo层@TableField(fill = FieldFill.INSERT)注解下面的字段
  2. new Date()是赋予我们现在时间的值
  3. 这个metaObject是传过去的对象
5.测试
@Test
    void update(){
        user user1=new user();
        user1.setId(1);
        user1.setUsername("王彦思12");
        int i = usermapper.updateById(user1);
        System.out.println(i);
    }

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值