在需要填充的字段上使用注解**@TableField(""),**给他的参数Fill设置值为对应的数据库操作,如添加,表明在添加的时候会进行填充,使用如下:
@TableField(fill = FieldFill.INSERT) private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) private Date modifyTime;
编写一个处理类继承MetaObjectHandler类,并重写对应的方法,在重写方法中设置填充的值。如下例子中,表明在插入的时候填充,将createTime(插入时间)和modifyTime(修改时间)设置为插入的时间。
@Component public class myAutoFill implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.setFieldValByName("createTime", new Date(), metaObject); this.setFieldValByName("modifyTime", new Date(), metaObject); } @Override public void updateFill(MetaObject metaObject) { this.setFieldValByName("modifyTime", new Date(), metaObject); } }
还要记得将这个类交给spring管理,加上Component注解。
id的生成方法有很多,比如uuid等,但是对于分布式的系统来说,uuid生成的id值还是有很小的概率可能重复;mybatisPlus3.3.0以前默认是使用雪花算法来生成数据库唯一的id。3.3.0以后是使用雪花算法+uuid来生成id。
雪花算法生成的是一个64位长整型的id,其中64位中由很多部分组成,从而保证它的唯一性。
第一个部分,是 1 个 bit:0,这个是无意义的。
第二个部分是 41 个 bit:表示的是时间戳
第三个部分是 5 个 bit:表示的是机房 id,10001。
第四个部分是 5 个 bit:表示的是机器 id,1 1001。
第五个部分是 12 个 bit:表示的序号,就是某个机房某台机器上这一毫秒内同时生成的 id 的序号,0000 00000000。
在实体类中id字段上加上TableId注解并噢诶之type参数为对应的生成策略即可。
@TableId(type = IdType.ASSIGN_ID) private Long id;