数据库的唯一标示符(ID)的选择

本文探讨了数据库设计中主键ID的选择,包括逻辑主键(如自增ID)和业务主键(如UUID、业务相关唯一键)的优缺点。逻辑主键避免业务变化带来的影响,提高查询性能,而业务主键更能反映业务含义,但在业务变化时可能需要更多维护。此外,文章还提到了数据量增大时水平分表对ID类型选择的影响。
摘要由CSDN通过智能技术生成

背景:数年的工作中,已经设计了很多系统或产品的数据库,有单机的、有局域网环境下的、也有互联网环境下的,对于不同的环境,设计考虑都有所不同。即使对于相同的环境,也会因为业务或者数据量的不同而有不同的设计。近期,又要设计一款互联网产品的数据库(MySQL服务)。经过之前的积累,在表的ID设计这个环节就进行了大量的分析、比较、学习,对ID的设计也有了更系统和深刻的认知,把自己学习实践到的知识总结下来,分享给大家。


主键id的选择

对于关系数据库来说,设计每个表的第一步都会确定其主键,主键就是ID。在“常识”之中,int型的自增id,字符串类型的uuid,其他与业务相关的唯一键…都是我们作为主键的选择。那么是不是说在一张表中只要能保证值唯一的属性列都可以做为主键或者更合适做主键呢?

那我们首先清晰几个概念:

  • 逻辑主键(代理主键):在数据库表中采用一个与当前表中业务逻辑信息无关的字段作为其主键,或称为“伪主键”;

  • 业务主键(自然主键):在数据库表中把具有业务逻辑含义的字段作为

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值