一、按逻辑角度划分
1、主键索引:主键索引是一种特殊的唯一索引,不允许有空值
2、普通索引或者单列索引
3、多列索引(复合索引):复合索引指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。使用复合索引时遵循最左前缀集合
4、唯一索引、非唯一索引
5、空间索引:空间索引是对空间数据类型的字段建立的索引,MYSQL中的空间数据类型有4种,分别是GEOMETRY、POINT、LINESTRING、POLYGON。MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。创建空间索引的列,必须将其声明为NOT NULL,空间索引只能在存储引擎为MYISAM的表中创建。
二、按数据结构角度划分
1、B+树索引:(关于B+树索引,可以参考 MySQL索引背后的数据结构及算法原理)
2、hash索引:(只有Memory存储引擎显示支持hash索引,仅仅能满足"=","IN"和"<=>"查询,不能使用范围查询,Hash 索引的查询效率要远高于 B-Tree 索引)
3、FULLTEXT索引:(现在MyISAM和InnoDB引擎都支持了)
4、R-Tree索引:(用于对GIS数据类型创建SPATIAL索引)
三、按物理存储角度划分
1、聚集索引(clustered index)
2、非聚集索引(non-clustered index)
聚集索引和非聚集索引的区别如下:
1) 聚集索引和非聚集索引的根本区别是表记录的排列顺序和与索引的排列顺序是否一致,聚集索引表记录的排列顺序与索引的排列顺序一致,优点是查询速度快,因为一旦
具有第一个索引值的纪录被找到,具有连续索引值的记录也一定物理的紧跟其后。
2) 聚集索引的缺点是对表进行修改速度较慢,这是为了保持表中的记录的物理顺序与索
引的顺序一致,而把记录插入到数据页的相应位置,必须在数据页中进行数据重排,
降低了执行速度,非聚集索引指定了表中记录的逻辑顺序,但记录的物理顺序和索引的顺序不一致。