从数据结构角度
1、B+ 树索引 (O(log(n))):关于 B + 树索引,可以参考 MySQL 索引背后的数据结构及算法原理
2、hash 索引:a 仅仅能满足 ”=”,”IN” 和 ”<=>” 查询,不能使用范围查询 b 其检索效率非常高,索引的检索可以一次定位,不像 B -Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的 IO 访问,所以 Hash 索引的查询效率要远高于 B-Tree 索引 c 只有 Memory 存储引擎显示支持 hash 索引
3、FULLTEXT 索引(现在 MyISAM 和 InnoDB 引擎都支持了)
4、R-Tree 索引(用于对 GIS 数据类型创建 SPATIAL 索引)
从物理存储角度
1、聚集索引(clustered index)
2、非聚集索引(non-clustered index)
从逻辑角度
1、主键索引:主键索引是一种特殊的唯一索引,不允许有空值
2、普通索引或者单列索引
3、多列索引(复合索引):复合索引指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。使用复合索引时遵循最左前缀集合
4、唯一索引或者非唯一索引
5、空间索引:空间索引是对空间数据类型的字段建立的索引,MYSQL 中的空间数据类型有 4 种,分别是 GEOMETRY、POINT、LINESTRING、POLYGON。MYSQL 使用 SPATIAL 关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。创建空间索引的列,必须将其声明为 NOT NULL,空间索引只能在存储引擎为 MYISAM 的表中创建
CREATE TABLE table_name[col_name data type]
[unique|fulltext|spatial][index|key][index_name](col_name[length])[asc|desc]
1、unique|fulltext|spatial 为可选参数,分别表示唯一索引、全文索引和空间索引;
2、index 和 key 为同义词,两者作用相同,用来指定创建索引
3、col_name 为需要创建索引的字段列,该列必须从数据表中该定义的多个列中选择;
4、index_name 指定索引的名称,为可选参数,如果不指定,MYSQL 默认 col_name 为索引值;
5、length 为可选参数,表示索引的长度,只有字符串类型的字段才能指定索引长度;
6、asc 或 desc 指定升序或降序的索引值存储