一、聚簇索引:
1、定义:
聚簇索引也叫聚集索引,它实际上并不是一种单独的索引类型,而是一种数据存储方式,聚簇索引的叶子节点保存了一行记录的所有列信息。也就是说,聚簇索引的叶子节点中,包含了一个完整的记录行。
2、特点:
①、使用记录主键值的大小进行记录和页的排序,使用记录主键值的大小进行记录和页的排序。
②、数据页内的记录是按照主键的大小顺序排成一个单向链表 。
③、各个存放记录行的页也是根据页中用户记录的主键大小顺序排成一个双向链表 。
④、存放目录项记录的页分为不同的层次,在同一层次中的页也是根据页中目录项记录的主键
在InnoDB中,每张表必须有一个聚簇索引,默认情况下会根据主键建立。如果表中没有主键,InnoDB会选择一个合适的列作为聚簇索引,如果找不到合适的列,会使用一列隐藏的列DB_ROW_ID作为聚簇索引。
二、非聚簇索引:
1、定义:
非聚簇索引也叫辅助索引、普通索引,它的叶子节点只包含主键值,通过非聚簇索引查找记录要先找到主键,然后通过主键再到聚簇索引中找到对应的记录行,这个过程被称为回表。
2、举例:
假如现在有一个包含了用户姓名的数据表,假设主键是用户的ID,
而一个非聚簇索引(以name为索引)的结构是:
除了name字段本身之外,在该节点的叶子节点中,仅包含当前记录的主键ID,而不包含完整记录的信息。需要通过name字段查找到相应的主键字段ID,再通过字段ID到聚簇索引中进行回表查询才能获取完整的记录行。
3:使用: