mysql聚簇索引与非聚簇索引

来源:互联网 发布:win10软件小助手 编辑:程序博客网 时间:2024/06/05 09:36

看了好多博客,感觉说的有点笼统,那么我就更笼统的说一下mysql的聚簇索引与非聚簇索引吧

首先说一下什么是mysql索引,有什么用。

       MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。

       索引分单列索引和组合索引。单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索引包含多个列。

创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。

实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

上面都在说使用索引的好处,但过多的使用索引将会造成滥用。因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

      建立索引会占用磁盘空间的索引文件。

     

      上边是从菜鸟教程中摘录出来的,足够理解什么是索引了,下面开始正题,什么是聚簇索引,什么是非聚簇索引



myisam存储引擎的创建的索引为聚簇索引

innodb存储引擎创建的索引是非聚簇索引

innodb的主索引文件上 直接存放该行数据,称为聚簇索引,次索引指向对主键的引用

myisam,主索引和次索引,都指向物理行(磁盘位置).

注意: innodb来说,

1: 主键索引 既存储索引值,又在叶子中存储行的数据

2: 如果没有主键,则会Unique key做主键

3: 如果没有unique,则系统生成一个内部的rowid做主键.

4: innodb,主键的索引结构中,既存储了主键值,又存储了行数据,这种结构称为聚簇索引


聚簇索引 

优势: 根据主键查询条目比较少时,不用回行(数据就在主键节点下)

劣势: 如果碰到不规则数据插入时,造成频繁的页分裂.

 

C) 聚簇索引的页分裂过程


http://blog.csdn.net/lijiaz5033/article/details/50129723