mysql和oracle主键生成策略_6.主键生成策略

本文详细介绍了Mybatis Plus的主键生成策略,包括默认的雪花算法、自定义策略、局部注解配置、全局配置以及扩展使用。重点讲解了如何通过IdType设置 AUTO、NONE、INPUT、ID_WORKER、UUID等不同策略,并展示了Oracle序列填充ID字段的示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

* [小书MybatisPlus第1篇-整合SpringBoot快速开始增删改查](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac1%e7%af%87-%e6%95%b4%e5%90%88springboot%e5%bf%ab%e9%80%9f%e5%bc%80%e5%a7%8b%e5%a2%9e%e5%88%a0%e6%94%b9%e6%9f%a5/.html)

* [小书MybatisPlus第2篇-条件构造器的应用及总结](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac2%e7%af%87-%e6%9d%a1%e4%bb%b6%e6%9e%84%e9%80%a0%e5%99%a8%e7%9a%84%e5%ba%94%e7%94%a8%e5%8f%8a%e6%80%bb%e7%bb%93/.html)

* [小书MybatisPlus第3篇-自定义SQL](http://www.zimug.com/other/java/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac3%e7%af%87-%e8%87%aa%e5%ae%9a%e4%b9%89sql/.html)

* [小书MybatisPlus第4篇-表格分页与下拉分页查询](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac3%e7%af%87-%e8%a1%a8%e6%a0%bc%e5%88%86%e9%a1%b5%e4%b8%8e%e4%b8%8b%e6%8b%89%e5%88%86%e9%a1%b5%e6%9f%a5%e8%af%a2/.html)

* [小书MybatisPlus第5篇-Active Record模式精讲](http://www.zimug.com/other/springboot/%e5%b0%8f%e4%b9%a6mybatisplus%e7%ac%ac5%e7%af%87-active-record%e6%a8%a1%e5%bc%8f%e7%b2%be%e8%ae%b2/.html)

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以后,主要有五种主键生成策略。

~~~java

public enum IdType {

/**

* 数据库ID自增,数据库需要支持主键自增(如MySQL),并设置主键自增

*/

AUTO(0),

/**

* 该类型为未设置主键类型,默认使用雪花算法生成

*/

NONE(1),

/**

* 用户输入ID,数据类型和数据库保持一致就行

*

该类型可以通过自己注册自动填充插件进行填充

*/

INPUT(2),

/* 以下3种类型、只有当插入对象ID 为空,才自动填充。 */

/**

* 全局唯一ID (idWorker),数值类型 数据库中也必须是数值类型 否则会报错

*/

ID_WORKER(3),

/**

* 全局唯一ID (UUID,不含中划线)

*/

UUID(4),

/**

* 字符串全局唯一ID (idWorker 的字符串表示),数据库也要保证一样字符类型

*/

ID_WORKER_STR(5);

}

~~~

## 三、局部注解配置策略

我们针对主键设置主键策略使用注解方式为

~~~java

@TableId(type = IdType.AUTO)

private long userId;

~~~

## 四、全局配置策略

~~~cpp

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;

~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值