首页 > 代码库 > MySQL之索引

MySQL之索引

1.什么是数据库索引

  索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录。表里面的记录数量越多,这个操作的代价就越高。如果作为搜索条件的列上已经创建了索引,MySQL无需扫描任何记录即可迅速得到目标记录所在的位置。如果表有1000个记录,通过索引查找记录至少要比顺序扫描记录快100倍。

2.索引的类型

  一、普通索引:这是最基本的索引类型,而且它没有唯一性之类的限制。普通索引可以通过以下几种方式创建,
      创建索引,例如CREATE INDEX <索引的名字> ON tablename (列的列表);
      修改表,例如ALTER TABLE tablename ADD INDEX [索引的名字] (列的列表);
      创建表的时候指定索引,例如CREATE TABLE tablename ( [...], INDEX [索引的名字] (列的列表) );

  二、唯一性索引:这种索引和前面的“普通索引”基本相同,但有一个区别:索引列的所有值都只能出现一次,即必须唯一。唯一性索引可以用以下几种方式创建,
      创建索引,例如CREATE UNIQUE INDEX <索引的名字> ON tablename (列的列表);
      修改表,例如ALTER TABLE tablename ADD UNIQUE [索引的名字] (列的列表);
      创建表的时候指定索引,例如CREATE TABLE tablename ( [...], UNIQUE [索引的名字] (列的列表) );

  三、主键索引:主键是一种唯一性索引,但它必须指定为“PRIMARY KEY”。如果你曾经用过AUTO_INCREMENT类型的列,你可能已经熟悉主键之类的概念了。主键一般在创      建表的时候指定,例如“CREATE TABLE tablename ( [...], PRIMARY KEY (列的列表) ); ”。但是,我们也可以通过修改表的方式加入主键,例如“ALTER TABLE                  tablename ADD PRIMARY KEY (列的列表); ”。每个表只能有一个主键。

  四、全文索引:在MySQL中,全文索引的索引类型为FULLTEXT。全文索引可以在VARCHAR或者TEXT类型的列上创建。它可以通过CREATE TABLE命令创建,也可以通过      ALTER TABLE或CREATE INDEX命令创建。对于大规模的数据集,通过ALTER TABLE(或者CREATE INDEX)命令创建全文索引要比把记录插入带有全文索引的空表更          快。 

  五、单列索引与多列索引:索引可以是单列索引,也可以是多列索引。

3.如何选择合适的列建立索引

  一、where、group by、order by、on从句中出现的

  二、索引字段越小越好

  三、建立联合索引的时候,需要考虑离散度打的列放到联合索引前面(离散度就是指取值的范围大小)

4.索引的维护与优化(重复以及冗余索引)

  一、定义:

    重复索引是指相同的列以相同的顺序建立相同类型的索引。

    冗余索引是指多个索引的前缀列相同,或是在联合索引中使用了主键的索引。

  二、查看是否含有冗余或者重复索引SQL(也可以使用命令行工具pt_duplicate_key_checker)

  

mysql> select a.table_schema  as ‘???‘,a.table_name as ‘??‘,a.index_name as ‘??1‘,b.index_name as ‘??2‘    -> ,a.column_name as ‘?????‘ from statistics a join statistics b on a.table_schema =b.table_schema    -> and  a.table_name = b.table_name and a.seq_in_index = b.seq_in_index and a.column_name = b.column_name    -> where a.seq_in_index = 1 and  a.index_name<>b.index_name;Empty set (0.48 sec)

  我的数据库表结构中没有重复或者是冗余的索引的。

  三、删除无用的索引

5.其他

    如果不能避免,你应该查看每张要结合起来的表,并且使用以上的策略来建立索引,然后再用EXPLAIN命令验证一下是否使用了你料想中的索引。如果是的话,就OK。不是的话,你可能要建立临时的表来将他们结合在一起,并且使用适当的索引。 要注意的是,建立太多的索引将会影响更新和插入的速度,因为它需要同样更新每个索引文件。对于一个经常需要更新和插入的表格,就没有必要为一个很少使用的where字句单独建立索引了,对于比较小的表,排序的开销不会很大,也没有必要建立另外的索引。

  

MySQL之索引