加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MYSQL数据库InnoDB表一定要用自增列做主键

发布时间:2020-12-12 00:49:25 所属栏目:MySql教程 来源:网络整理
导读:《MYSQL数据库InnoDB表一定要用自增列做主键》要点: 本文介绍了MYSQL数据库InnoDB表一定要用自增列做主键,希望对您有用。如果有疑问,可以联系我们。 导读:综上总结,如果InnoDB表的数据写入顺序能和B+树索引的叶子节点顺序一致的话,这时候存取效率是最高

《MYSQL数据库InnoDB表一定要用自增列做主键》要点:
本文介绍了MYSQL数据库InnoDB表一定要用自增列做主键,希望对您有用。如果有疑问,可以联系我们。

导读:综上总结,如果InnoDB表的数据写入顺序能和B+树索引的叶子节点顺序一致的话,这时候存取效率是最高的,也就是下面这几种情况的存取效率最高: 我们先了解下InnoDB引擎表的一些关键特征:
  • MYSQL应用InnoDB引擎表是基于B+树的索引组织表(IOT);

  • MYSQL应用每个表都需要有一个聚集索引(clustered index);

  • MYSQL应用所有的行记录都存储在B+树的叶子节点(leaf pages of the tree);

  • MYSQL应用基于聚集索引的增、删、改、查的效率相对是最高的;

  • MYSQL应用如果我们定义了主键(PRIMARY KEY),那么InnoDB会选择其作为聚集索引;

  • MYSQL应用如果没有显式定义主键,则InnoDB会选择第一个不包含有NULL值的唯一索引作为主键索引;

  • MYSQL应用如果也没有这样的唯一索引,则InnoDB会选择内置6字节长的ROWID作为隐含的聚集索引(ROWID随着行记录的写入而主键递增,这个ROWID不像ORACLE的ROWID那样可引用,是隐含的).

MYSQL应用?

MYSQL应用综上总结,也就是下面这几种情况的存取效率最高:

  • MYSQL应用使用自增列(INT/BIGINT类型)做主键,这时候写入顺序是自增的,和B+数叶子节点分裂顺序一致;

  • MYSQL应用该表不指定自增列做主键,同时也没有可以被选为主键的唯一索引(上面的条件),这时候InnoDB会选择内置的ROWID作为主键,写入顺序和ROWID增长顺序一致;

  • MYSQL应用除此以外,如果一个InnoDB表没有显式主键,但有可以被选择为主键的唯一索引,且该唯一索引可能不是递增关系时(例如字符串、UUID、多字段联合唯一索引的情况),该表的存取效率就会特别差.

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

MYSQL应用附图:

MYSQL应用1、B+树典型结构

InnoDB表一定要用自增列做主键|MySQL优化系列



2、InnoDB主键逻辑结构

InnoDB表一定要用自增列做主键|MySQL优化系列



延伸阅读:

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

MYSQL应用2、B+Tree index structures in InnoDB,192);">http://blog.jcole.us/2013/01/10/btree-index-structures-in-innodb/

MYSQL应用3、B+Tree Indexes and InnoDB – Percona,192);">http://www.percona.com/files/presentations/percona-live/london-2011/PLUK2011-b-tree-indexes-and-innodb.pdf

MYSQL应用4、MySQL官方手册: Clustered and Secondary Indexes,?

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

MYSQL应用?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读