數據庫設計>>>創建時間/更新時間自動填充

數據庫設計>>>創建時間/更新時間自動填充@TOC

創建時間/更新時間自動填充

阿里巴巴開發手冊:所有的數據庫表都要配置上gmt_create、gmt_modified!而且需要自動化!

方式一

數據庫級別(工作中一般不用, 這種方式不用代碼實現,數據庫自動填充)

1、在表中新增字段 gmt_create, gmt_modified
2、把實體類同步

private Date gmtCreate;
private Date gmtModified;

3、數據庫設計
數據庫設計

測試:

更新一條記錄

@Test
    void upDataUser() {
   
   
        User user = new User();
        user.setId(1347883372479614979L);
        user.setName("劉德華");
        user.setAge(58);
        user.setEmail("[email protected]");

        int result = userMapper.updateById(user);
        System.out.println("result>>>" + result);
        System.out.println("user" + user);
    }

更新後的結果:
在這裏插入圖片描述

方式二:代碼級別

1、數據庫字段
在這裏插入圖片描述

2、實體類字段屬性上需要增加註解

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
   
   
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
    @TableField(value = "gmt_create",fill = FieldFill.INSERT)
    private LocalDateTime gmtCreate;

    @TableField( value = "gmt_modified",fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime gmtModified;
}

3、編寫處理器來處理這個註解即可!(可以參考官網)
“gmtModified” 指的是實體類屬性的名字 還有要注意日期類型一樣

package link.zishu.handler;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;

import java.time.LocalDateTime;
import java.util.Date;

@Component // 一定不要忘記把處理器加到IOC容器中!
public class MyMetaObjectHandler implements MetaObjectHandler {
   
   
    // 插入時的填充策略
    @Override
    public void insertFill(MetaObject metaObject) {
   
   
        System.out.println("start insert fill.....");
        this.strictInsertFill(metaObject, "gmtCreate", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推薦使用)
        this.strictInsertFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推薦使用)
    }

    // 更新時的填充策略
    @Override
    public void updateFill(MetaObject metaObject) {
   
   
        //"gmtModified" 指的是實體類屬性的名字     還有要注意日期類型一樣
        this.strictUpdateFill(metaObject, "gmtModified", LocalDateTime.class, LocalDateTime.now());
    }
}

測試

@Test
    void upDataUser() {
   
   
        User user = new User();
        user.setId(1347883372479614988L);
        user.setName("劉德華");
        user.setAge(58);
        user.setEmail("[email protected]");

        int result = userMapper.updateById(user);
        System.out.println("result>>>" + result);
        System.out.println("user" + user);
    }

結果

在這裏插入圖片描述

附 (註解填充字段的選項)

public enum FieldFill {
   
   
    /**
     * 默認不處理
     */
    DEFAULT,
    /**
     * 插入填充字段
     */
    INSERT,
    /**
     * 更新填充字段
     */
    UPDATE,
    /**
     * 插入和更新填充字段
     */
    INSERT_UPDATE
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章