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

文章目录

      • 前言
      • 什么是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.mfbz.cn/a/183666.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

java SpringCloud版本b2b2c鸿鹄云商平台全套解决方案 小程序商城免费搭建

使用技术: Spring CloudSpring BootMybatis微服务服务监控可视化运营 B2B2C平台: 平台管理端(包含自营) 商家平台端(多商户入驻) PC买家端、手机wap/公众号买家端 微服务(30个通用微服务如:商品、订单、购物车、个人中心、支…

c#数据库:vs2022 加入mysql数据源

网上有VS2019连接MySQL数据库的,那么VS2022,VS2023如果和连接到mysql数据库呢,这里总结一下我的经历: 1、首先下载ODBC驱动安装包 当前下载地址:https://dev.mysql.com/downloads/connector/odbc/ 2、ODBC安装 下载完…

qgis添加wms服务

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

Linux - 文件系统 - 理解目录 - 理解 软/硬链接

前言 在上篇博客当中,我们对 文件系统 和 inode 做了初步了解,本博客将在上篇博客的基础之上,对于 文件系统当中的目录进行进步一阐述。 Linux - 进一步理解 文件系统 - inode - 机械硬盘-CSDN博客 目录 一个文件有一个 inode,…

【面试送分题!“商品分类浏览”如何测试?】

电商项目无论是工作中,还是面试中,都是一个高频出现的词。 面试官非常热衷提问关于电商项目的问题。例如商品分类怎么测试?购物车怎么测试?订单怎么测试?优惠券怎么测试?支付怎么测试?等等。 …

tcp/ip协议2实现的插图,数据结构2 (19 - 章)

(68) 68 十九1 选路请求与消息 函rtalloc,rtalloc1,rtfree (69)

【硬核HeyGen平替】在window平台上使用MyHeyGen

最近在研究HeyGen的平替开源项目,然后发现了MyHeyGen这个项目,但是文档上面并没有说明如果在window平台上使用,考虑到非window平台安装显卡驱动什么的比较繁琐,所以尝试硬着头皮干... 前提 开源项目中所需的环境准备要先准备好 1…

线性空间(也叫向量空间)、线性运算

线性空间、线性运算 线性空间,也称向量空间。 假设是一个非空集合,是一个实数域。 在中定义了一个加法:即对中任何两个元素和,总有中另外一个元素与它们相对应,称为和的和,记作: 在定义了一个…

在全球碳市场中崭露头角的中碳CCNG

在全球气候治理的大背景下,中国碳中和发展集团有限公司(简称中国碳中和)正在成为全球碳交易市场的一个重要参与者。随着国际社会对碳排放的日益关注,中国碳中和凭借其在碳资产开发、咨询与管理等领域的深厚积累,正成为…

机器学习/sklearn笔记:MeanShift

1 算法介绍 一种基于质心的算法通过更新候选质心使其成为给定区域内点的均值候选质心的位置是通过一种称为“爬山”技术迭代调整的,该技术找到估计的概率密度的局部最大值 1.1 基本形式 给定d维空间的n个数据点集X,那么对于空间中的任意点x的均值漂移…

ArgoWorkflow教程(一)---DevOps 另一选择?云原生 CICD: ArgoWorkflow 初体验

来自:探索云原生 https://www.lixueduan.com 原文:https://www.lixueduan.com/posts/devops/argo-workflow/01-deploy-argo-workflows/ 本文主要记录了如何在 k8s 上快速部署云原生的工作流引擎 ArgoWorkflow。 ArgoWorkflow 是什么 Argo Workflows 是…

解决:前端js下载文件流出现“未知文件格式”错误

第一中情况: 出现的问题,前端已经设置了responseType: blob,下载下来还是格式不对。 最后经过排查,后端缺少charsetutf-8,所以前端可以设置编码: 第二中情况: 后端已经设置了charsetutf-8,前…

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

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

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

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

Java Web 实战 21 - 用 Servlet 实现一个Hello World

用 Servlet 来写一个 Hello World~ 一 . 基本部署方式1.1 创建 Servlet 项目1.2 引入依赖1.3 创建目录1.4 编写代码继承 HttpServlet重写 doGet 方法删除 super 方法加上 WebServlet 注解写业务逻辑 1.5 打包1.6 部署1.7 验证1.8 小结 二 . 更方便的部署方式2.1 Smart Tomcat 的…

首批!创邻科技入选《图数据库金融应用场景优秀案例》

11月11日,“全球金融科技中心网络年会”在第三届全球金融科技大会暨第五届成方金融科技论坛上成功在京举办。会上,北京前沿金融监管科技研究院发布了基于国际标准组织——国际关联数据基准委员会(LDBC)的《图数据库金融应用场景优…

REST教程

越来越多的人开始意识到,网站即软件,而且是一种新型的软件。这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点。 …

利用MATLAB进行矩阵运算

一、画出y1/(x3)的函数曲线,x∈[0, 200]。 程序: x0:0.01:200; y(3x).^(-1); plot(x,y) 结果: 二、生成一个信号:xsin(2*pi*t)cos(4*pi*t) 程序: syms t; xsin(2*pi*t).*cos(4*pi*t); fplot(x,[0 pi]); 结果&…

飞书智能伙伴之 AI 数智参谋:先进团队,北极星指标也要遥遥领先

11 月 22 日,飞书在 2023 秋季飞书未来无限大会上正式发布了飞书智能伙伴。作为首批生态伙伴,基于 Kyligence 智能一站式指标平台实现的 AI 数智参谋也正式亮相。这是继 11 月 21 日 Kyligence 产品发布会后,Kyligence 在数据驱动决策智能领域…

医学生秋招攻略,面试时一定要注意这些方面!

医学生别拖了,今年秋招已经过去一波热度了,赶早不赶晚!在筹备第二轮秋招以及明年的春招的医学生一定要注意以下事项。 1.清晰目标 搜集秋招讯息 一定要早点多做准备,想清楚未来的目标,是继续深造还是就业做医生或者是…
最新文章