主键策略整理

数据库自增长

优点:
1)简单,代码方便,性能可以接收。
2)数字ID天然排序,对分页或者需要排序的结果很有帮助。
缺点:
​ 1)不同数据库语法和实现不同,数据库迁移的时候或多个数据库版本支持的时候需要处理。
​ 2)在单个数据库或读写分离或一主多从的情况下,只有一个主库可以生成。有单点故障的风险。

解决方法:如果有多个Master库,则每个Master库设置的起始数字不一样,步长一样,可以是Master的个数。比如:Master1 生成的是 1,4,7,10,Master2生成的是2,5,8,11 Master3生成的是 3,6,9,12。这样就可以有效生成集群中的唯一ID,也可以大大降低ID生成数据库操作的负载

​ 3)在性能达不到要求的情况下,比较难于扩展。
​ 4)如果遇见多个系统需要合并或者涉及到数据库会相当痛苦。
​ 5)分表分库的时候会有麻烦。

UUID

优点:
​ 1)简单,代码方便。
​ 2)生成ID性能非常好,基本不会有性能问题。
​ 3)全球唯一,在遇见数据迁移,系统数据合并,或者数据库变更等情况下,可以从容应对。

缺点:
​ 1)没有

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值