使用雪花id或uuid作为Mysql主键,被媳妇怼了一顿

本文探讨了在mysql中使用雪花id和uuid作为主键的优缺点,通过实验发现,自增id在插入效率上优于uuid,尤其是在大数据量时。文章分析了uuid导致的随机IO、页分裂和数据碎片问题,建议尽量使用自增id以减少性能损耗。同时,也指出了自增id在并发和隐私保护方面的挑战。
摘要由CSDN通过智能技术生成

前言:在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究竟有什么坏处?本篇博客我们就来分析这个问题,探讨一下内部的原因。

一、mysql和程序实例

1.1 要说明这个问题,我们首先来建立三张表

分别是user_auto_key,user_uuid,user_random_key,分别表示自动增长的主键,uuid作为主键,随机key作为主键,其它我们完全保持不变。根据控制变量法,我们只把每个表的主键使用不同的策略生成,而其他的字段完全一样,然后测试一下表的插入速度和查询速度:

注:这里的随机key其实是指用雪花算法算出来的前后不连续不重复无规律的id:一串18位长度的long值

id自动生成表:

用户uuid表

随机主键表:

1.2 光有理论不行,直接上程序,使用spring的jdbcTemplate来实现增查测试:

技术框架:

springboot+jdbcTemplate+junit+hutool

程序的原理就是连接自己的测试数据库,然后在相同的环境下写入同等数量的数据,来分析一下insert插入的时间来进行综合其效率,为了做到最真实的效果,所有的数据采用随机生成,比如名字、邮箱、地址都是随机生成。

package com.wyq.mysqldemo;
import cn.hutool.core.collection.CollectionUtil;
import com.wyq.mysqldemo.databaseobject.UserKeyAuto;
import com.wyq.mysqldemo.databaseobject.UserKeyRandom;
import com.wyq.mysqldemo.databaseobject.UserKeyUUID;
import com.wyq.mysqldemo.diffkeyt
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
雪花算法是一种生成唯一ID的方法,由LinkedIn开源并广泛应用于各种分布式系统,包括数据库、缓存等场景。这种算法能够生成足够大的空间用于ID分配,同时保证生成的ID全局唯一。 雪花算法的基本思想: 1. **时间戳** - 41位数字表示当前时间(从1970年1月1日到当前的时间),每秒可以产生大约16亿个ID(因为有10毫秒级的时间戳精度)。 2. **工作机器ID** - 10位数字标识了服务器的工作节点,通常是一个三位数范围内的值。理论上可以支持4096个工作节点(即2^12 = 4096)。 3. **序列号** - 最后的12位数字表示同一毫秒内产生的序号,它可以提供大约16384次连续操作的可能性(即2^12)。这意味着在同一毫秒内,最多可以有16384个独立的操作(如创建一个新的会话或事务)得到相同的序列号,但这不会影响整体的唯一性。 ### UUID(Universally Unique Identifier) UUID是一个通用的唯一识别符,主要用于跨平台应用及需要长时间保持唯一性的场景。UUID由四个部分组成: 1. **时间戳** - 类似于雪花算法的时间戳部分,表示生成该ID的时间点。 2. **设备ID** - 包含用于生成UUID的设备信息,通常是MAC地址的一部分。 3. **随机数** - 可能是从真随机数生成器(TRNG)获取的数据,用于增强UUID的随机性和安全性。 4. **版本号** - 表示UUID的生成方式或兼容性级别。 UUID具有更高的唯一性,因此更适合对数据一致性要求较高的场景,比如在不同服务器间共享的唯一标识。 ### MySQL主键索引 MySQL主键索引是指定表用于唯一标识每一行数据的一个字段或一组字段。当创建一张表并定义某个列作为主键时,MySQL自动为其建立一个B树索引,这使得基于这个字段的查询非常高效。 关键特点: 1. **唯一性** - 主键约束要求主键值在整个表必须是唯一的。 2. **非空性** - 主键列不允许为空值,除非明确指定允许NULL值。 3. **查询效率** - 使用主键可以快速定位表的特定行,特别是在大数据量的情况下。 4. **触发器和外键关联** - 主键常常与其他表的外键关联,帮助维护数据的一致性和完整性。 主键索引对于优化查询性能至关重要,尤其是涉及到大量数据和频繁查询的场景。合理设计和选择主键字段可以极大地提高数据库系统的运行效率。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值