dengzedong
2024-12-26 efdc380e66bbc3112eb87d7522f0a37d082082e1
提交 | 用户 | 时间
e7c126 1 package com.iailab.framework.mybatis.core.dataobject;
H 2
3 import com.baomidou.mybatisplus.annotation.FieldFill;
4 import com.baomidou.mybatisplus.annotation.TableField;
5 import com.baomidou.mybatisplus.annotation.TableLogic;
6 import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
7 import com.fhs.core.trans.vo.TransPojo;
8 import lombok.Data;
9 import org.apache.ibatis.type.JdbcType;
10
11 import java.io.Serializable;
12 import java.time.LocalDateTime;
13
14 /**
15  * 基础实体对象
16  *
17  * 为什么实现 {@link TransPojo} 接口?
18  * 因为使用 Easy-Trans TransType.SIMPLE 模式,集成 MyBatis Plus 查询
19  *
20  * @author iailab
21  */
22 @Data
23 @JsonIgnoreProperties(value = "transMap") // 由于 Easy-Trans 会添加 transMap 属性,避免 Jackson 在 Spring Cache 反序列化报错
24 public abstract class BaseDO implements Serializable, TransPojo {
25
26     /**
27      * 创建时间
28      */
29     @TableField(fill = FieldFill.INSERT)
30     private LocalDateTime createTime;
31     /**
32      * 最后更新时间
33      */
34     @TableField(fill = FieldFill.INSERT_UPDATE)
35     private LocalDateTime updateTime;
36     /**
37      * 创建者,目前使用 SysUser 的 id 编号
38      *
39      * 使用 String 类型的原因是,未来可能会存在非数值的情况,留好拓展性。
40      */
41     @TableField(fill = FieldFill.INSERT, jdbcType = JdbcType.VARCHAR)
42     private String creator;
43     /**
44      * 更新者,目前使用 SysUser 的 id 编号
45      *
46      * 使用 String 类型的原因是,未来可能会存在非数值的情况,留好拓展性。
47      */
48     @TableField(fill = FieldFill.INSERT_UPDATE, jdbcType = JdbcType.VARCHAR)
49     private String updater;
50     /**
51      * 是否删除
52      */
53     @TableLogic
54     private Boolean deleted;
55
56 }