数字主键

单列的数字主键一般有三种:

一、自增主键

如果是用多个数据库时候,可以调整数据库自增主键的起始值以及step大小。

pro: 简单实现;可以代表插入时间早晚;

con:必须实际插入后才能拿到主键数,从而导致效率低;用多个数据库后,无法保证数据库间的数据有序

 

二、uuid

pro:全时空唯一,撞车概率很低很低;加上时间戳可以有序;

con:基本都要求存储空间>96bits;增加了应用程序复杂性;

 

三、时间戳+机器码+自增数类型的,如snowflake

pro:64bit空间即可;有序;

con:会引入新的服务

 

参照:instagram的例子

 

你可能感兴趣的:(数字主键)