共计 1895 个字符,预计需要花费 5 分钟才能阅读完成。
本文为 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 深入浅出系列》