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

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 |       |
+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL 聚簇索引和非聚簇索引有很大的不同。MySQL 聚簇索引,也称为 InnoDB 引擎,是一种特殊的索引类型,其特点是所有的数据都存储在索引节点中。这种索引类型提供了快速插入和更新,但是缺点是不支持全文索引和 FULLTEXT 索引,而且索引节点间的数据距离很近,因此索引也相对较大。MySQL聚簇索引,也称为 MyISAM 引擎,是一种常规索引类型,其特点是每个索引节点只存储索引值,数据存储在另外一个表中,所以索引文件可以很小。它支持全文索引和 FULLTEXT 索引,速度比聚簇索引慢,但对于非常大的表来说,它的性能更高。 ### 回答2: MySQL中,InnoDB和MyISAM是两种常用的存储引擎。在介绍聚簇索引和非聚簇索引之前,需要先了解这两种存储引擎InnoDB是一种支持ACID事务的存储引擎,它更适合于具有高并发和处理大量写操作的应用。MyISAM则没有提供事务支持,适用于读操作较多的应用。 聚簇索引是根据表的主键构建的索引,它定义了表内数据的物理排列顺序。InnoDB存储引擎主键索引聚簇索引聚簇索引将数据存储在索引的叶子节点中,通过B+树的结构来进行快速查找和范围扫描。优势在于通过主键索引,可以快速检索到表的全部数据行,并且在插入新数据时可以减少页的分裂和合并操作。 非聚簇索引是在表的外部构建的索引,它包含了非主键列的索引。MyISAM存储引擎使用的索引就是非聚簇索引。非聚簇索引将数据和索引分开存储,索引中的节点通过指向对应数据行的指针来访问数据。由于数据和索引是分开存储的,因此在利用非聚簇索引进行查询时,需要根据索引找到对应的主键值,再通过主键值找到数据行,这增加了一部分IO操作。 总结来说,InnoDB聚簇索引和MyISAM的非聚簇索引的区别主要体现在数据存储和访问方式上。聚簇索引将数据行和索引行存储在一起,可以加快查询速度,减少IO操作。而非聚簇索引将数据和索引分开存储,导致查询数据时需要多次IO操作。根据具体的应用场景和需求,我们可以选择合适的存储引擎索引类型。 ### 回答3: MySQL中的聚簇索引和非聚簇索引是两种不同类型的索引,它们在存储和访问数据方面有一些区别。这些区别在InnoDB和MyISAM引擎中有所不同。 InnoDB引擎中的聚簇索引以数据行的物理排序顺序存储数据。这意味着,当使用聚簇索引进行数据访问时,MySQL将按照聚簇索引的排序顺序来读取数据,这样可以提高查询性能。另外,在InnoDB引擎中,聚簇索引主键索引或唯一索引。如果表没有主键或唯一索引InnoDB将生成一个隐藏的聚簇索引。 相比之下,MyISAM引擎中的非聚簇索引是一种独立于数据的数据结构,它通过指向数据行的物理位置来进行数据访问。这意味着,当使用非聚簇索引进行数据访问时,MySQL需要先通过索引获取到数据的物理位置,然后再通过物理位置读取数据。由于数据和索引在不同的位置存储,因此查询性能可能会稍低于使用聚簇索引。 另一个区别是,使用聚簇索引的表在插入新数据时,数据行会被以聚簇索引的排序顺序插入到表中。而使用非聚簇索引的表在插入新数据时,数据行会被追加到表的末尾。因此,InnoDB引擎中使用聚簇索引的表在插入新数据时可能会导致页分裂,而MyISAM引擎中使用非聚簇索引的表则不会发生。 总的来说,聚簇索引适用于常常进行范围查询或按照特定顺序查询的表,因为它可以通过减少磁盘I/O来提高查询性能。非聚簇索引则适用于需要快速定位特定行的表。根据具体的应用场景和需求,选择合适的索引类型可以提高MySQL的性能和效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值