https://blog.csdn.net/rocling/article/details/83116950
自增主键与UUID的优缺点
rocling 2018-10-17 20:15:02 8062 收藏 8
分类专栏: sql java 文章标签: sql
版权
自增主键
自增ID是在设计表时将id字段的值设置为自增的形式,这样当插入一行数据时无需指定id会自动根据前一字段的ID值+1进行填充。在MySQL数据库中,可通过sql语句AUTO_INCREMENT来对特定的字段启用自增赋值 使用自增ID作为主键,能够保证字段的原子性.
优点
数据库自动编号,速度快,而且是增量增长,按顺序存放,对于检索非常有利;
数字型,占用空间小,易排序,在程序中传递也方便;
如果通过非系统增加记录时,可以不用指定该字段,不用担心主键重复问题。
缺点
因为自动增长,在手动要插入指定ID的记录时会显得麻烦,尤其是当系统与其它系统集成时,需要数据导入时,很难保证原系统的ID不发生主键冲突(前提是老系统也是数字型的)。特别是在新系统上线时,新旧系统并行存在,并且是异库异构的数据库的情况下,需要双向同步时,自增主键将是你的噩梦;
在系统集成或割接时,如果新旧系统主键不同是数字型就会导致修改主键数据类型,这也会导致其它有外键关联的表的修改,后果同样很严重;
若系统也是数字型的,在导入时,为了区分新老数据,可能想在老数据主键前统一加一个字符标识(例如“o”,old)来表示这是老数据,那么自动增长的数字型又面临一个挑战。
UUID
UUID含义是通用唯一识别码 (Universally Unique Identifier),指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。通常平台会提供生成的API。换句话说能够在一定的范围内保证主键id的唯一性。
优点
出现数据拆分、合并存储的时候,能达到全局的唯一性
缺点
影响插入速度, 并且造成硬盘使用率低
uuid之间比较大小相对数字慢不少, 影响查询速度。
uuid占空间大, 如果你建的索引越多, 影响越严重
- 点赞2
- 评论1
- 收藏8
- 手机看
- 打赏
- 关注
华为机考题库(全)
12-22
包括招聘的机考题,及面试过程中会问到的数据结构的相关内容,排序算法全部包括并且有改进算法,一点点改进可以让你表现的与众不同,如果好的话给点评价吧亲
自增还是UUID?MYSQL数据库主键的类型选择
weixin_43101678的博客
1万+
自增还是UUID?这个问题看似简单,但是能诱发很多思考,也涉及到了很多细节。网上的确有很多有关这方面的资料,但是比较乱,今天我结合这些资料和自己的心得,单独对这个话题写一篇博客出来,希望对大家有所帮助哈。 先说下uuid和 auto_increment(数据库自增主键)的优缺点吧,因为是个人理解,如有错误恳请指出: auto_incremen的优点: 字段长度较uuid小很多,可以是big...
-
JoieLu:对于拆分 我用EXCEL合并130万条数据 然后主键就用EXCEL自动生成,所以在数据量大的情况下还是推荐自增ID,加快效率,哪怕0.1秒13天前回复