Mybatis-Plus中的几种主键生成策略

本文详细介绍了Mybatis-Plus中的主键生成策略,包括数据库自增长、UUID、UUID to Int64、Redis生成ID、Twitter的Snowflake算法、Zookeeper生成唯一ID以及MongoDB的ObjectId。在分布式系统中,每种策略都有其优缺点,如数据库自增长的简单性和局限性,UUID的全球唯一性与无序性,以及Snowflake算法的分布式递增特性。Mybatis-Plus则提供了多种策略供开发者选择,如ID_WORKER等。
摘要由CSDN通过智能技术生成

一、Mybatis-Plus中的主键生成策略

​ 在设计数据库时,我们可以仅仅指定主键,但是不指定主键的生成策略,在持久化数据时再指定主键的生成策略。

1、分布式系统中主键的生成策略

​ 在分布式系统中,常见的主键生成策略有以下几种:

1.1 数据库自增长序列或字段

​ 最常见的方式。利用数据库,全数据库唯一。

​ 优点:

​ 1)简单,代码方便,性能可以接受。

​ 2)数字ID天然排序,对分页或者需要排序的结果很有帮助。

​ 缺点:

​ 1)不同数据库语法和实现不同,数据库迁移的时候或多数据库版本支持的时候需要处理。

​ 2)在单个数据库或读写分离或一主多从的情况下,只有一个主库可以生成。有单点故障的风险。

​ 3)在性能达不到要求的情况下,比较难于扩展。

​ 4)如果遇见多个系统需要合并或者涉及到数据迁移会相当痛苦。

​ 5)分表分库的时候会有麻烦。

​ 优化方案:

​ 针对主库单点,如果有多个Master库,则每个Master库设置的起始数字不一样,步长一样,可以是Master的个数。比如:Master1 生成的是 1,4,7,10,Master2生成的是2,5,8,11 Master3生成的是 3,6,9,12。这样就可以有效生成集群中的唯一ID,也可以大大降低ID生成数据库操作的负载。类似于Redis的生成策略

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值