本文为mybatis系列文档的第6篇,前5篇请拜访上面的网址。

  • 小书MybatisPlus第1篇-整合SpringBoot疾速开始增删改查
  • 小书MybatisPlus第2篇-条件结构器的利用及总结
  • 小书MybatisPlus第3篇-自定义SQL
  • 小书MybatisPlus第4篇-表格分页与下拉分页查问
  • 小书MybatisPlus第5篇-Active Record模式精讲

Mybatis Plus 为咱们提供了三种设置 主键生成策略的形式。它们的优先级程序是:部分注解 > 全局 > 默认(雪花算法)。上面咱们来一一介绍

一、默认主键生成策略:雪花算法

Mybatis Plus如果不做任何主键策略配置,默认应用的是雪花算法。该策略会依据雪花算法生成主键ID,主键类型为Long或String(具体到MySQL数据库就是BIGINT和VARCHAR),该策略应用接口IdentifierGenerator的办法nextId(默认实现类为DefaultIdentifierGenerator雪花算法)

snowflake算法是Twitter开源的分布式ID生成算法,后果是一个long类型的ID 。其核心思想:应用41bit作为毫秒数,10bit作为机器的ID(5bit数据中心,5bit的机器ID),12bit作为毫秒内的流水号(意味着每个节点在每个毫秒能够产生4096个ID),最初还有一个符号位,永远是0。

二、自定义主键策略

mybatis-plus3.3.0当前,次要有五种主键生成策略。

public enum IdType {    /**     * 数据库ID自增,数据库须要反对主键自增(如MySQL),并设置主键自增     */    AUTO(0),    /**     * 该类型为未设置主键类型,默认应用雪花算法生成     */    NONE(1),    /**     * 用户输出ID,数据类型和数据库保持一致就行     * <p>该类型能够通过本人注册主动填充插件进行填充</p>     */    INPUT(2),    /* 以下3种类型、只有当插入对象ID 为空,才主动填充。 */    /**     * 全局惟一ID (idWorker),数值类型  数据库中也必须是数值类型 否则会报错     */    ID_WORKER(3),    /**     * 全局惟一ID (UUID,不含中划线)     */    UUID(4),    /**     * 字符串全局惟一ID (idWorker 的字符串示意),数据库也要保障一样字符类型     */    ID_WORKER_STR(5);}

三、部分注解配置策略

咱们针对主键设置主键策略应用注解形式为

@TableId(type = IdType.AUTO)private long userId;

四、全局配置策略

mybatis-plus:  global-config:    db-config:      id-type: auto

五、扩大应用

5.1.INPUT用户输出ID策略的用法

其中须要和大家非凡介绍的是:Input(用户输出ID),这个ID起源能够有两种

  • 用户本人设置ID,并在insert之前SET主键的值
  • 一些有序列的数据库,比方Oracle,SQLServer等,针对这些数据库咱们能够通过序列填充ID字段

Mybatis-Plus 内置了如下数据库主键序列(如果内置反对不满足你的需要,可实现 IKeyGenerator 接口来进行扩大):

  • DB2KeyGenerator
  • H2KeyGenerator
  • KingbaseKeyGenerator
  • OracleKeyGenerator
  • PostgreKeyGenerator

以Oracle 的Sequence应用办法为例,应用办法如下:
首先增加@Bean

 @Bean    public OracleKeyGenerator oracleKeyGenerator(){        return new OracleKeyGenerator();    }

而后实体类配置主键 Sequence,指定主键策略为 IdType.INPUT 即可,

@Data@KeySequence(value = "SEQ_USER" , clazz = Long.class)public class User {    @TableId(value = "ID",type = IdType.INPUT)    private Integer id;

欢送关注我的博客,外面有很多精品合集

  • 本文转载注明出处(必须带连贯,不能只转文字):字母哥博客。

感觉对您有帮忙的话,帮我点赞、分享!您的反对是我不竭的创作能源! 。另外,笔者最近一段时间输入了如下的精品内容,期待您的关注。

  • 《手摸手教你学Spring Boot2.0》
  • 《Spring Security-JWT-OAuth2一本通》
  • 《实战前后端拆散RBAC权限管理系统》
  • 《实战SpringCloud微服务从青铜到王者》
  • 《VUE深入浅出系列》