第一种:自动增长
常见的方式:比如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
当使用数据库