[MySQL] innoDB引擎的主键与聚簇索引

本文深入解析MySQL InnoDB引擎的聚簇索引机制,包括根据主键、非空唯一索引或隐藏row-id形成的聚簇索引,以及如何通过主键查询达到最高效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql的innodb引擎本身存储的形式就必须是聚簇索引的形式 , 在磁盘上树状存储的 , 但是不一定是根据主键聚簇的 , 有三种情形:

1. 有主键的情况下 , 主键就是聚簇索引

2. 没有主键的情况下 , 第一个非空null的唯一索引就是聚簇索引

3. 如果上面都没有 , 那么就是有一个隐藏的row-id作为聚簇索引

 

大部分情况下 , 我们建表的时候都会创建主键 , 因此大部分都是根据主键聚簇的 

当我们根据主键字段来进行查询时 , 效率是最高的 , 不需要二次查找 , 直接主键字段查询索引树 , 叶子节点就是存储的数据了

 

当我们根据主键查询时 , 如果就只有唯一一条 , 那么执行计划是下面这样的 , 差不多是最高效的 . type是const  row只需要扫描一行

+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+
| id | select_type | table | type  | possible_keys | key     | key_len | ref   | rows | Extra |
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+
|  1 | SIMPLE      | tblz  | const | PRIMARY       | PRIMARY | 4       | const |    1 |       |
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+

 

### MySQL InnoDB 索引索引的区别及工作原理 #### 一、定义 - **索引**是指表中的记录按照索引顺序物理存储的数据结构,在InnoDB中,每张表只能拥有一个索引。通常情况下,这个索引就是主键索引;如果没有显式指定,则会选择第一个唯一且非空的列作为索引[^3]。 - **非索引**(Secondary Index),又称为辅助索引或二级索引,其叶子节点并不包含完整的行数据,而是只保存了该条目对应的索引键值(通常是主键)。当通过非索引来查找某一行时,先定位到相应的非索引项,再利用其中存储的索引键访问实际的数据行[^4]。 #### 二、内部结构差异 对于采用B+树形式构建的索引来说: - 在索引里,叶级节点包含了全部的用户数据字段以及事务ID和回滚指针等隐藏信息; - 对于非索引而言,除了上述提到的仅存有指向对应索引位置的信息外,其余部分均为空白填充物以保持固定大小以便高效管理磁盘空间[^1]。 #### 三、性能影响 由于两者之间存在这样的结构性差别,因此在执行不同类型的查询操作时会产生不同的表现效果: - 使用索引进行范围扫描非常有效率,因为所需读取的数据页连续存在于硬盘上; - 当涉及到频繁更新特定字段而这些字段又被设为了非索引的一部分时可能会引起较多页面分裂现象从而降低整体性能; - 如果经常基于某些条件过滤并返回大量结果集的话建议创建覆盖索引——即让所涉及的所有列都成为某个非索引的一部分来减少二次I/O次数[^5]。 ```sql CREATE INDEX idx_name ON table(column_list); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值