Mybatis-Plus 自定义id生成器

1.自定义ID生成器是mp的核心功能。默认使用雪花算法+UUID(不含中划线)

Mybatis-Plus 自定义id生成器_第1张图片

2.共有以下几种生成策略

        ①、AUTO :id自增

        ②、NONE :不设置id生成策略,一般和第一个一样都是用数据库自增的

        ③、 ASSIGN_ID :雪花算法生成id

Mybatis-Plus 自定义id生成器_第2张图片

        ④、ASSIGN_UUID:以UUid算法生成id

                ASSIGN_UUID是自动生成的一个不重复的、长度为32位的字符串,也能在分布式系统中使用

                使用时需要注意:实体类的主键应该为long类型,表中主键类型设置为bigint类型,表中主键类型用bigint对应java中的long

                缺点比较明显:生成的主键是32位的字符串,长度过长占用空间而且还不能排序,查询性能也慢

 3.Unix时间戳是从1970年1月1日开始所经过的秒数,不考虑闰秒

4.使用UUid作为主键id的弊端

        ①、生成的id里面有字母

        ②、他是没有顺序的

5.雪花算法生成的id也是递增的,UUid的性能要比雪花算法差

6.为什么要用雪花算法而不用数据库递增

        ①、数据库的递增是靠数据库来实现的,容易给数据库带来压力,而优秀的架构设计往往想办法给数据库减轻压力(Redis缓存,内存缓存)

        ②、分表时用数据库递增会有重复主键

7.分布式id生成策略

为什么用分布式id:有多个库且要保证这些库id是唯一的

        ①、雪花算法(弊端:id太长)

        ②、redis Incr:每次新增从redis中去拿数据,每次加一且具有原子性(不会重复)(我们可以一次性从redis中取20条数据放本地缓存,用完之后再从数据库中取,这样只需要一次访问redis的io)

你可能感兴趣的:(mybatis,java,数据库)