索引介绍

什么是索引?为什么要建立索引?

      索引用于快速在某一列中找到特定的值,不适用索引的话,mysql必须从读取这张表的所有记录,直到找到相关的值,表越大查找数据所花费的时间就越多。如果所要查找的列中有索引的话,MySQL就能快速到达一个位置去搜素数据文件,而不必查看所有数据,因此使用索引将节省很多时间。
       例如:有一张person表,其中有2W条记录,记录着2W个人的信息。有一个Phone的字段记录每个人的电话号码,现在想要查询出电话号码为xxxx的人的信息。如果没有索引,那么将从表中第一条记录一条条往下遍历,直到找到该条信息为止。如果有了索引,那么会将该Phone字段,通过一定的方法进行存储,好让查询该字段上的信息时,能够快速找到对应的数据,而不必在遍历2W条数据了。
       Mysql中的索引的存储类型有两种,BTREE、HASH。也就是用树或者hash值来存储该字段,要知道其中详细是如何查找的,就需要会算法的知识了。我们现在只需要知道索引的作用,功能是什么就行。

MySQL中索引的优缺点和使用原则

  • 优点:
           1. 所有的MySQL列类型(即字段类型)都可以被索引,也就是可以给任意字段设置索引。
           2. 大大加快了数据的查询速度。
  • 缺点:
           1. 创建索引和维护索引要耗费时间,并且随着数据量的增加所耗费的时间也会增加。
           2. 索引也需要占空间,我们知道数据表中的数据也会有再大上限的设置。一张表有多个索引,这些索引会被存放到一个专门存储索引的文件中,如果大量使用索引,索引文件可能会比数据文件更快达到上限值。
  • 使用原则:
           1. 并不是每个字段设置索引就好,也不是索引越多越好,需要自己合理的设置索引。
           2. 对经常更新的标就避免对其使用过多的索引,对经常查询的字段应该创建索引。
           3. 如果一个字段的值很少就不要创建索引,如:性别只有男女就不要再创建索引。相反,如果一个字段可取的值特别多就要创建字段,如:id,每个id都是不同的,这就需要创建索引。

索引引擎

索引是在存储引擎中实现的,也就是说不同的存储引擎会使用不同的索引。

  • MyISAM和InnoDB存储引擎:值支持BTREE索引,即默认使用BTREE,不能更换。
  • MEMORY/HEAP存储引擎:支持HASH和BTREE索引。

索引分类

索引可以分为四类:单列索引(普通索引,唯一索引,逐主键索引)、组合索引、全文索引、空间索引。

  • 单列索引:一个索引只包含单个列,但是一个表可以有多个单列索引。
           1. 普通索引:MySQL中基本索引类型,没有什么限制,允许在定义索引的列中插入重复的值和空值,纯粹为了查询数据更快。
           2. 唯一索引:索引列中的值必须是惟一的,但是允许为空值。
           3. 主键索引:是一种特殊的唯一索引,不允许有空值。
  • 组合索引:
           1. 用表中的多个字段组合创建索引,只有在查询条件中使用了这些字段中左边的字段时,索引才会被使用,使用组合索引时遵循: 最左前缀集合。
  • 全文索引:
           1. 全文索引,只有在MyISAM引擎中才能使用,只能在char,varchar,text类型的字段上使用。介绍了要求,说说什么是全文索引,就是在一堆文字中,通过其中的某个关键字等,就能找到该字段所属的记录行,可能就可以找到该条记录。这里说的是可能,因为全文索引的使用涉及了很多细节,我们只需要知道这个大概意思。
  • 空间索引:
           1. 空间索引是对空间数据类型的字段建立的索引,MySQL中的空间数据类型有四种,GEOMETRY、POINT、LINESTRING、POLYGON。
           2. 在创建空间索引时,使用SPATIAL关键字。
           3. 要求引擎为MyISAM,创建空间索引的列,必须将其声明为NOT NULL。