索引说明

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

  • 拿汉语字典的目录页(索引)打比方,我们可以按拼音、笔画、偏旁部首等排序的目录(索引)快速查找到需要的字。

  • 索引分单列索引和组合索引:

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

    组合索引,即一个索引包含多个列。

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

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

  • 上面都在说使用索引的好处,但过多的使用索引将会造成滥用。

    因此索引也会有它的缺点:虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

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

索引类型

INDEX(普通索引)

普通索引是mysql中最基本的索引类型,它没有任何限制,唯一任务就是加快系统对数据的访问速度。

普通索引允许在定义索引的列中插入重复值和空值

创建普通索引时,通常使用的关键字是index或key

SQL语句添加方式:

CREATE INDEX indexName ON table_name (column_name)//新建
ALTER table tableName ADD INDEX indexName(columnName)//修改表结构添加普通索引

UNIQUE(唯一索引)

唯一索引与普通索引类似,不同的是创建唯一性索引的目的不是为了提高访问速度,而是为了避免数据出现重复。

唯一索引列的值必须唯一,允许有空值。

如果是组合索引,则列值的组合必须唯一。

创建唯一索引通常使用 unique 关键字。

SQL语句添加方式:

CREATE UNIQUE INDEX indexName ON table_name (column_name(length)) //新建
ALTER table mytable ADD UNIQUE [indexName] (column_name(length))//修改表结构添加唯一索引

FULLTEXT(全文索引)

全文索引主要用来查找文本中的关键字,只能在 CHAR、VARCHAR 或 TEXT 类型的列上创建。

在 MySQL 中只有 MyISAM 存储引擎支持全文索引

全文索引允许在索引列中插入重复值和空值。

不过对于大容量的数据表,生成全文索引非常消耗时间和硬盘空间。

创建全文索引使用 FULLTEXT 关键字。

CREATE FULLTEXT INDEX index_name ON table_name(column_name);

SPATIAL(空间索引)

空间索引是对空间数据类型的字段建立的索引,使用 SPATIAL 关键字进行扩展。

创建空间索引的列必须将其声明为 NOT NULL,空间索引只能在存储引擎为 MyISAM 的表中创建。

空间索引主要用于地理空间数据类型 GEOMETRY。对于初学者来说,这类索引很少会用到。

SQL语句添加方式:

CREATE SPATIAL INDEX index_name ON table_name(column_name);

PRIMARY KEY(主键索引)

顾名思义,主键索引就是专门为主键字段创建的索引,也属于索引的一种。

主键索引是一种特殊的唯一索引,不允许值重复或者值为空。

创建主键索引通常使用 PRIMARY KEY 关键字。不能使用 CREATE INDEX 语句创建主键索引。

索引实际使用区分

索引在逻辑上分为以上 5 类,但在实际使用中,索引通常被创建成单列索引和组合索引。

单列索引

单列索引就是索引只包含原表的一个列。在表中的单个字段上创建索引,单列索引只根据该字段进行索引。

单列索引可以是普通索引,也可以是唯一性索引,还可以是全文索引。

只要保证该索引只对应一个字段即可。

多列索引

组合索引也称为复合索引或多列索引。

相对于单列索引来说,组合索引是将原表的多个列共同组成一个索引。多列索引是在表的多个字段上创建一个索引。

该索引指向创建时对应的多个字段,可以通过这几个字段进行查询。

但是,只有查询条件中使用了这些字段中第一个字段时,索引才会被使用。

例如:在表中的 id、name 和 sex 字段上建立一个多列索引,那么,只有查询条件使用了 id 字段时,该索引才会被使用。

提示

一个表可以有多个单列索引,但这些索引不是组合索引。

一个组合索引实质上为表的查询提供了多个索引,以此来加快查询速度。

比如:在一个表中创建了一个组合索引(c1,c2,c3),在实际查询中,系统用来实际加速的索引有三个:单个索引(c1)、双列索引(c1,c2)和多列索引(c1,c2,c3)。