【MySQL】mysql中不推荐使用uuid或者雪花id作为主键的原因以及差异化对比

news2024/12/26 0:08:05

文章目录

      • 前言
      • 什么是UUID?
      • 什么是雪花ID?
      • 什么是MySql自增ID?
      • 优缺点对比
        • UUID:
          • 优点
            • 1.全球唯一性
            • 2.无需数据库支持
          • 缺点
            • 1.存储空间大
            • 2.索引效率低
            • 3.查询效率低
        • 雪花ID:
          • 优点
            • 1.分布式环境下唯一性
          • 缺点
            • 1.依赖于机器时钟
            • 2.存储空间较大
            • 3.查询效率低
        • MYSQL自增:
          • 优点
            • 1.简单易用
            • 2.唯一性
            • 3.效率高
            • 4.索引效率高
          • 缺点
            • 1.不适用于分布式系统
            • 2.不适用于需要保密的场景
            • 3.查询效率低
      • 应用场景
        • UUID应用场景
          • 1.分布式系统
          • 2.高并发环境
          • 3.需要保密的场景
        • 雪花ID应用场景
          • 1.分布式系统
          • 2.高并发环境
        • MySQL自增ID应用场景
          • 1.单机系统
          • 2.高效查询
          • 3.索引效率高
      • 总结
      • 写在最后

579a429daf314744b995f37351b46548

前言

在数据库设计中,选择适当的主键类型对于数据的存储和查询效率至关重要。在MySQL中,有些开发者倾向于使用UUID(Universally Unique Identifier)或者雪花ID作为主键,以确保数据的唯一性。然而,这种做法并不总是推荐的,因为它们在性能、存储空间和索引效率等方面存在一些问题。本文将探讨在MySQL中不推荐使用UUID或者雪花ID作为主键的原因,并与其他主键类型进行差异化对比。


什么是UUID?

UUID(Universally Unique Identifier)是一种标识符,用于在计算机系统中唯一地标识实体。它是一个128位的数字,通常以32个十六进制数字的形式表示,中间用连字符分隔。UUID的生成算法保证了在理论上不同计算机和不同时间生成的UUID都是唯一的。

UUID的唯一性和广泛应用使得它在分布式系统、数据库、网络通信等领域得到广泛使用。它可以用于标识数据库记录、文件、消息、会话等各种实体,确保它们在不同的系统和时间下都能够被唯一标识。


什么是雪花ID?

雪花ID(Snowflake ID)是一种分布式唯一ID生成算法,由Twitter公司开发。它的设计目标是在分布式系统中生成全局唯一的ID,以解决传统自增ID在分布式环境下可能出现的冲突和性能瓶颈问题。

雪花ID的结构如下:

  1. 符号位(1位):始终为0,表示正数。
  2. 时间戳(41位):记录生成ID的时间戳,精确到毫秒级。
  3. 数据中心ID(5位):用于标识数据中心,最多支持32个数据中心。
  4. 机器ID(5位):用于标识机器,最多支持每个数据中心32台机器。
  5. 序列号(12位):每个节点在同一毫秒内生成的序列号,最多支持每毫秒生成4096个ID。

通过将时间戳、数据中心ID、机器ID和序列号组合在一起,雪花ID可以在分布式系统中生成全局唯一的ID。由于时间戳占据了较高的位数,所以雪花ID生成的ID是递增的,可以保证在一定程度上的有序性。


什么是MySql自增ID?

MySQL自增ID是一种由MySQL数据库管理系统提供的主键生成机制。它通过自动递增的方式为每条插入的记录生成一个唯一的ID值,用于标识该记录在表中的唯一性。

在MySQL中,自增ID通常与整数类型的列(如INT或BIGINT)结合使用。当插入一条新记录时,MySQL会自动为该列生成一个唯一的ID值,下一次插入时会自动递增。这样可以确保每条记录都有一个唯一的标识符,方便进行数据的查找、更新和删除操作。


优缺点对比

UUID:
优点
1.全球唯一性

​ UUID在全球范围内保证了唯一性,不会出现重复的情况。

2.无需数据库支持

​ UUID的生成不依赖于数据库,可以在应用层生成。

缺点
1.存储空间大

​ UUID占用的存储空间较大,通常为36个字符,如果作为主键,会占用更多的存储空间。

2.索引效率低

​ UUID是随机生成的,不具有顺序性,导致索引效率较低。

3.查询效率低

​ 由于索引效率低,查询效率也会受到影响。

雪花ID:
优点
1.分布式环境下唯一性

​ 雪花ID在分布式系统中生成唯一的ID,可以满足分布式环境下的需求。

缺点
1.依赖于机器时钟

​ 雪花ID的生成依赖于机器的时钟,如果时钟回拨或者时钟不同步,可能会导致生成的ID不唯一。

2.存储空间较大

​ 雪花ID占用的存储空间较大,通常为64位,如果作为主键,会占用更多的存储空间。

3.查询效率低

​ 由于雪花ID是随机生成的,不具有顺序性,导致索引效率较低。

MYSQL自增:
优点
1.简单易用

​ MySQL自增ID的生成由数据库自动完成,无需额外的代码逻辑。

2.唯一性

​ 自增ID保证了每条记录都有一个唯一的标识符。

3.效率高

​ 自增ID是按顺序递增的,可以提高插入和查询的效率。

4.索引效率高

​ 自增ID可以作为主键或索引列,提高查询效率。

缺点
1.不适用于分布式系统

​ 在分布式环境下,多个节点生成的自增ID可能会冲突,需要额外的处理机制。

2.不适用于需要保密的场景

​ 自增ID的递增规律可能暴露系统的使用情况,不适用于需要保密的业务场景。

3.查询效率低

​ 由于雪花ID是随机生成的,不具有顺序性,导致索引效率较低。

综上所述,虽然UUID和雪花ID在某些场景下具有唯一性和分布式支持的优点,但由于存储空间大、索引效率低等缺点,以及不适用于分布式和保密场景,不推荐将它们作为主键。相比之下,MySQL自增ID具有简单易用、唯一性、效率高和索引效率高等优点,适用于大多数场景,因此推荐使用自增ID作为主键。


应用场景

UUID应用场景
1.分布式系统

​ 由于UUID的全球唯一性,可以在分布式系统中生成唯一的标识符,避免冲突。

2.高并发环境

​ UUID的生成不依赖于数据库,可以在应用层生成,减少数据库的压力。

3.需要保密的场景

​ UUID是随机生成的,不具有递增规律,适用于需要保密的业务场景。

雪花ID应用场景
1.分布式系统

​ 雪花ID可以在分布式系统中生成唯一的ID,满足分布式环境下的需求。

2.高并发环境

​ 雪花ID的生成不依赖于数据库,可以在应用层生成,减少数据库的压力。

MySQL自增ID应用场景
1.单机系统

​ MySQL自增ID适用于单机系统,由数据库自动生成,简单易用。

2.高效查询

​ 自增ID是按顺序递增的,可以提高插入和查询的效率。

3.索引效率高

​ 自增ID可以作为主键或索引列,提高查询效率。

综上所述,UUID适用于分布式系统和需要保密的场景,雪花ID适用于分布式系统和高并发环境,MySQL自增ID适用于单机系统和高效查询的场景。根据具体的业务需求和系统架构,选择合适的主键类型。


总结

选择适当的主键类型对于数据库的性能和可扩展性至关重要。

在MySQL中,使用自增整数作为主键是一种常见的做法,因为它具有较小的存储空间、高效的索引和自动增长的特性。

相比之下,使用UUID或者雪花ID作为主键可能会导致性能下降、存储空间浪费和索引效率降低等问题。

然而,具体选择何种主键类型还是要根据具体的业务需求和数据特点来决定。

通过本文的介绍和对比,希望读者能够更好地理解在MySQL中不推荐使用UUID或者雪花ID作为主键的原因,并能够根据实际情况做出明智的选择。


写在最后

感谢您的支持和鼓励! 😊🙏

如果大家对相关文章感兴趣,可以关注公众号"架构殿堂",会持续更新AIGC,java基础面试题, netty, spring boot, spring cloud等系列文章,一系列干货随时送达!

csdn-end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1245627.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

聚类算法模型的概念、评估及应用

聚类是一种无监督学习方法,其目标是将数据集中的样本分成不同的组别,使得同一组内的样本相似度较高,而不同组之间的样本相似度较低。聚类算法模型通常通过计算样本之间的相似度或距离来实现这一目标。以下是聚类算法模型的概念、评估及应用的…

电脑技巧:推荐八个非常实用的在线网站值得收藏

目录 1、wikihow 干货分享网站 2、次元小镇 二次元必备网站 3、AI创作家 4、SKRbt 搜索引擎网站 5、barbg 全球资源网站 6、书签地球 7、4KHDR世界 8、a real me 今天小编给大家推荐八个非常实用的在线网站值得收藏! 1、wikihow 干货分享网站 这个网站是一…

文章解读与仿真程序复现思路——电工技术学报EI\CSCD\北大核心《面向差异化电源成本结构的容量市场机制设计》

这个文章标题涉及到容量市场机制设计,着重考虑了电源成本结构的差异性。下面对标题中的关键词进行解读: 面向(Facing): 表示该容量市场机制设计是以某种方向、取向或目标为基础的。在这里,可能指的是设计是…

九州未来联合联通智网科技发布白皮书,促进车联网融合发展

2023年11月21日,由2023中国5G工业互联网大会组委会、工业和信息化部主办,联通智网科技承办的2023中国5G工业互联网大会——5G车联网与智慧交通创新发展平行会议,在武汉成功举办。 九州未来作为中国联通车联网创新联合体成员单位,受…

自学编程,用好这几个网站就够了!

如果你要自学编程,一定要收藏好这7个网站,上面免费的优质教程很多,完全可以省去你上万块钱的学费! 话不多说,直接上干货! 第一个,W3school 一个主打图文教程的网站,不管是前端开发…

域控操作五:统一熄屏睡眠时间

直接看图路径,我只设置了熄屏,如果要睡眠就下面那个启用设置时间

本地部署 ComfyUI

本地部署 ComfyUI ComfyUI 介绍ComfyUI Github 地址部署 ComfyUI配置模型地址 or 下载模型启动 ComfyUI访问 ComfyUI ComfyUI 介绍 最强大、模块化的稳定扩散 GUI 和后端。 该用户界面将允许您使用基于图形/节点/流程图的界面设计和执行高级稳定扩散管道。 ComfyUI Github 地…

123. 股票买卖的最佳时机III(2次交易)

题目 题解 class Solution:def maxProfit(self, prices: List[int]) -> int:N len(prices)# 状态定义 dp[i][j][k]代表在第i天,被允许完成j次交易时,持有或者不持有的最大利润。k0代表不持有,k1代表持有dp [[[0 for k in range(2)] for…

反爬虫机制与反爬虫技术(二)

反爬虫机制与反爬虫技术二 1、动态页面处理与验证码识别概述2、反爬虫案例:页面登录与滑块验证码处理2.1、用例简介2.2、库(模块)简介2.3、网页分析2.4、Selenium准备操作2.5、页面登录2.6、模糊移动滑块测试3、滑块验证码处理:精确移动滑块3.1、精确移动滑块的原理3.2、滑…

Centos部署GitLab-备份恢复

1. 下载rpm包 wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-10.8.4-ce.0.el7.x86_64.rpm2. 安装依赖 yum -y install policycoreutils openssh-server openssh-clients postfix policycoreutils-python3. rpm安装 rpm -ivh gitlab-ce-10.8.4-ce.…

Selenium介绍及基本使用方法

Selenium是一个开源、免费、简单、灵活,对Web浏览器支持良好的自动化测试工具,在UI自动化、爬虫等场景下是十分实用的,能够熟练掌握并使用Selenium工具可以大大的提高效率。 Selenium简介 Selenium支持多平台、多浏览器、多语言去实现自动化…

【开源】基于Vue.js的固始鹅块销售系统

项目编号: S 060 ,文末获取源码。 \color{red}{项目编号:S060,文末获取源码。} 项目编号:S060,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 鹅块类型模块2.3 固…

EPT-Net:用于3D医学图像分割的边缘感知转换器

EPT-Net: Edge Perception Transformer for 3D Medical Image Segmentation EPT-Net:用于3D医学图像分割的边缘感知转换器背景贡献实验方法Dual Positional Transformer(双位置Transformer)Learnable Patch EmbeddingVoxel Spacial Positiona…

【开源】基于Vue.js的用户画像活动推荐系统

项目编号: S 061 ,文末获取源码。 \color{red}{项目编号:S061,文末获取源码。} 项目编号:S061,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 兴趣标签模块2.3 活…

[C++历练之路]优先级队列||反向迭代器的模拟实现

W...Y的主页 😊 代码仓库分享💕 🍔前言: 在C的宇宙中,优先队列似乎是一座巨大的宝库,藏匿着算法的珍宝。而就在这片代码的天空下,我们不仅可以探索优先队列的神奇,还能够揭开反向迭…

C# Onnx PP-Vehicle 车辆分析(包含:车辆检测,识别车型和车辆颜色)

目录 效果 模型信息 mot_ppyoloe_s_36e_ppvehicle.onnx vehicle_attribute_model.onnx 项目 代码 下载 其他 C# Onnx PP-Vehicle 车辆分析(包含:车辆检测,识别车型和车辆颜色) 效果 模型信息 mot_ppyoloe_s_36e_ppvehi…

聚观早报 |一加12正式开启预订;OPPO Reno11系列卖点

【聚观365】11月24日消息 一加12正式开启预订 OPPO Reno11系列卖点 小鹏第三季度营收财报 Claude 2.1 聊天机器人公布 现代汽车将与伦敦大学学院合作 一加12正式开启预订 全新的一加12系列公开亮相已有一段时间,不久前一加官方宣布,该机将于12月4日…

Ubuntu20.04清理垃圾vscode缓存

使用VM虚拟机安装了Ubuntu系统,主目录空间越来越小,硬盘扩容之后很快又空间不足,甚至出现了开机卡黑屏的情况,这里记录一下解决过程。 1 重新开机进入系统 状态:卡到了开机黑屏状态,左上角有一条小横杠 原…

居家适老化设计第二十八条---卫生间之地漏

以上产品图片均来源于淘宝网,侵权联系删除 居家适老化的地漏是为了满足老年人和身体不便者的需求,使其能够更方便、安全地使用,具有以下特点:1. 防滑设计:地漏表面的材质采用防滑处理,以防止老人在使用过程…

qgis添加wms服务

例如添加geoserver的wms服务 左右浏览器-WMS/WMTS-右键-新建连接 URL添加geoserver的wms地址 http://{ip}:{port}/geoserver/{workspace}/wms 展开wms目录,双击相应图层即可打开