mybatisPlus自动填充属性

属性的自动填充

1.设置填充的字段和填充操作

在需要填充的字段上使用注解**@TableField(""),**给他的参数Fill设置值为对应的数据库操作,如添加,表明在添加的时候会进行填充,使用如下:

 @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date modifyTime;

2.设置填充的值:

编写一个处理类继承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的生成

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生成测试

在实体类中id字段上加上TableId注解并噢诶之type参数为对应的生成策略即可。

@TableId(type = IdType.ASSIGN_ID)
    private Long id;
上一篇:字符串匹配的sunday算法


下一篇:Spring MVC 关于分页的简单实现