雪花算法、uuid和自增id的区别
创始人
2024-05-31 20:03:55
0

自增id:

自增的主键的值是顺序的。

优点:
1.自增,趋势自增,可作为聚集索引,提升查询效率
2.节省磁盘空间。500W数据,UUID占5.4G,自增ID占2.5G.
3.查询,写入效率高:查询略优。在数据量大时候高于uuid插入速度

缺点:
1.导入旧数据时,可能会ID重复,导致导入失败。
2.分布式架构,多个Mysql实例可能会导致ID重复。
3.容易被外界攻破,知道业务实际情况。且例如:显示公告内容index?id=3这样就很容易被人篡改为index?id=2.就可以调到第二条的内容。
4对于分库操作,id不能重复,所以我们最好使先从MySQL获取一批自增ID,加载到本地内存中,然后从内存中取。

UUID:

在一定的范围内唯一的机器生成的标识符,通用唯一标识符

可以以业务实际user id为主键 比如QQ号 手机号等。

优点:随机生成,不会重复。

缺点:uuid中带有字符串,32位字符串会占用更大的空间,无序的字符串作数据库主键,每次插入数据库的时候,MySQL为了维护B+树结构,需要频繁调整节点顺序,影响性能。


雪花id :

相比UUID无序生成的id而言,雪花算法是有序的(有时间参数),而且都是由数字组成。

雪花id最大为64位,符合java中long的长度64位。

适用于大规模分布式

优点:

1.引入了时间戳,保证ID能够按照时间有序生成,索引效率高   

2.分布式系统不会产生ID碰撞,并且效率较高

3.高性能高可用:不依赖第三方库或者中间件,完全在内存中生成,可用性强

4.容量大:每秒中能生成数百万的自增ID。

缺点:

 依赖与系统时间的一致性,如果系统时间被回调,或者改变,可能会造成id冲突或者重复。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...