开发者社区> xaubllxwtvaqiu> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

[MySQL FAQ]系列 — 为什么InnoDB表要建议用自增列做主键

简介: [MySQL FAQ]系列 — 为什么InnoDB表要建议用自增列做主键
+关注继续查看

我们先了解下InnoDB引擎表的一些关键特征:

  • InnoDB引擎表是基于B+树的索引组织表(IOT);
  • 每个表都需要有一个聚集索引(clustered index);
  • 所有的行记录都存储在B+树的叶子节点(leaf pages of the tree);
  • 基于聚集索引的增、删、改、查的效率相对是最高的;
  • 如果我们定义了主键(PRIMARY KEY),那么InnoDB会选择其作为聚集索引;
  • 如果没有显式定义主键,则InnoDB会选择第一个不包含有NULL值的唯一索引作为主键索引;
  • 如果也没有这样的唯一索引,则InnoDB会选择内置6字节长的ROWID作为隐含的聚集索引(ROWID随着行记录的写入而主键递增,这个ROWID不像ORACLE的ROWID那样可引用,是隐含的)。


综上总结,如果InnoDB表的数据写入顺序能和B+树索引的叶子节点顺序一致的话,这时候存取效率是最高的,也就是下面这几种情况的存取效率最高:

  • 使用自增列(INT/BIGINT类型)做主键,这时候写入顺序是自增的,和B+数叶子节点分裂顺序一致;
  • 该表不指定自增列做主键,同时也没有可以被选为主键的唯一索引(上面的条件),这时候InnoDB会选择内置的ROWID作为主键,写入顺序和ROWID增长顺序一致;
  • 除此以外,如果一个InnoDB表又没有显示主键,又有可以被选择为主键的唯一索引,但该唯一索引可能不是递增关系时(例如字符串、UUID、多字段联合唯一索引的情况),该表的存取效率就会比较差。



实际情况是如何呢?经过简单TPCC基准测试,修改为使用自增列作为主键与原始表结构分别进行TPCC测试,前者的TpmC结果比后者高9%倍,足见使用自增列做InnoDB表主键的明显好处,其他更多不同场景下使用自增列的性能提升可以自行对比测试下。


附图:

1、B+树典型结构

image.png

2、InnoDB主键逻辑结构

image.png


延伸阅读:

1、TPCC-MySQL使用手册, http://imysql.com/2012/08/04/tpcc-for-mysql-manual.html

2、B+Tree index structures in InnoDB, http://blog.jcole.us/2013/01/10/btree-index-structures-in-innodb/

3、B+Tree Indexes and InnoDB – Percona, http://www.percona.com/files/presentations/percona-live/london-2011/PLUK2011-b-tree-indexes-and-innodb.pdf

4、MySQL官方手册: Clustered and Secondary Indexes,

https://dev.mysql.com/doc/refman/5.6/en/innodb-index-types.html

            </div>

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【MySQL】MySQL的安装与配置
安装环境:Win10 64位 软件版本:MySQL 5.7.24 解压版
45 0
【MySQL】Navicat的安装(详解版)
下载安装包 下载地址:http://www.navicat.com.cn/download/navicat-premium 找到对应自己电脑的版本,下载安装包,Navicat提供14免费。这里我安装的是Navicat16、64bit
34 0
【分享】MySQL安装、配置环境、创建数据库的方法
学习MySQL安装、配置环境、创建数据库的方法。
36 0
Docker安装MySQL并使用Navicat连接
Docker安装MySQL并使用Navicat连接
25 0
linux下 如何安装mysql
linux下 如何安装mysql
28 0
Linux/UNIX 上安装 MySQL
Linux/UNIX 上安装 MySQL
20 0
MySQL安装时常见问题和解决方案【详解】
包含了MySQL安装时常见问题和解决方案,快捷实用
45 0
linux常用软件安装-jdk.tomcat,mysql
linux常用软件安装-jdk.tomcat,mysql
21 0
Ubuntu下安装mysql并初始化密码
Ubuntu下安装mysql并初始化密码 安装并初始化远程访问
63 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
MySQL表和索引优化实战
立即下载
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL
立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL
立即下载