首页 > 代码库 > 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之索引