常见的主键生成策略

第一种:自动增长常见的方式:比如mysql中可以直接给字段设置 auto increment好处:1、代码方便,简单易用,性能可接受2、数字天然排列,对分页和需要排序的结果有帮助缺点:1、不同数据库或者不同版本数据库的语法和实现不同,数据迁移的时候可能需要处理2、在性能达不到要求的情况下,难于扩展3、如果需要多个系统合并或者涉及到数据库迁移会比较痛苦4、分表分库的时候会有麻烦5、在读写分离或者一主多从的情况下,只有一个主库生成,有单点故障的风险优化方案: 如果有多个master库,可以
摘要由CSDN通过智能技术生成

第一种:自动增长

常见的方式:比如mysql中可以直接给字段设置 auto increment

好处:
1、代码方便,简单易用,性能可接受
2、数字天然排列,对分页和需要排序的结果有帮助

缺点:
1、不同数据库或者不同版本数据库的语法和实现不同,数据迁移的时候可能需要处理
2、在性能达不到要求的情况下,难于扩展
3、如果需要多个系统合并或者涉及到数据库迁移会比较痛苦
4、分表分库的时候会有麻烦
5、在读写分离或者一主多从的情况下,只有一个主库生成,有单点故障的风险

优化方案: 如果有多个master库,可以给每个master设置步长,如135,248

第二种:UUID

常见的方式:利用数据库或者程序生成

好处:
1、简单,代码方便
2、生成ID性能好
3、全球唯一,在遇见数据库迁移,系统数据合并,或者数据库变更情况下,可以从容应对

缺点:
1、没有排序,无法保证趋势递增
2、UUID往往使用字符串,查询效率较低
3、存储空间较大,如果是海量数据库,就需要考虑储量问题
4、传输数据量大
5、不可读

第三种:Redis生成ID

当使用数据库

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值