单列的数字主键一般有三种:
一、自增主键
如果是用多个数据库时候,可以调整数据库自增主键的起始值以及step大小。
pro: 简单实现;可以代表插入时间早晚;
con:必须实际插入后才能拿到主键数,从而导致效率低;用多个数据库后,无法保证数据库间的数据有序
二、uuid
pro:全时空唯一,撞车概率很低很低;加上时间戳可以有序;
con:基本都要求存储空间>96bits;增加了应用程序复杂性;
三、时间戳+机器码+自增数类型的,如snowflake
pro:64bit空间即可;有序;
con:会引入新的服务
参照:instagram的例子