Mysql - 为啥不建议UUID当主键

1. 不能当主键的原因:

MySQL写入数据时,会把数据存放到索引页中。使用UUID作为主键,新行的主键值不一定比之前的主键值大,所以innoDb无法做到总是把新行插入到索引的最后,而需要为新行寻找合适的位置来分配新的空间(因为是B+树方式存储的)。

要分配新的空间,就要知道应该分到哪个页。如果用自增主键等,直接顺序增加在后面。而UUID类,就需要排序后这儿插一个,哪儿插一个。不够的话,还要页分裂。而且,随机值载入到聚簇索引,有时候会需要做一次OPTIMEIZE TABLE来重建标并优化页的填充,这将又需要一定的时间消耗。

2. 不好,那为啥大家还要用?那有什么其他措施?

用自增主键有以下问题:

a. 可能存在根据ID值爬取数据库记录,有安全风险;
b. 系统重构或者与其他系统集成时,可能存在新老主键冲突;
c. 并发插入会导致间隙锁竞争;
d. 分库分表场景下的ID生成;
e. 自增主键有限,要考虑主键长度问题。

随便想想:

1. 分库分表的场景,可以修改步长;

2. 系统重构或者其他系统集成,是不是可以预留一段ID专用,做ID转换;

3. 是不是可以依赖redis,获取锁段,然后内存计算ID,做为主键;

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值