MySQL索引的设计和使用

时间:2023-03-08 23:02:01
MySQL索引的设计和使用

一、索引可以有效地提升SELECT操作的性能,同时会影响UPDATE、CREATE和DELETE操作的性能。每种引擎对于表的索引有数量和长度的限制。

二、索引的设计原则

  (A) 搜索的索引列,不一定是要选择的列,最适合索引的列是where子句的列或连接子句中的列。

  (B) 使用唯一索引,索引列的基础越大,索引的效果越好。

  (C) 使用短索引,如果对字符串列(char,varchar,text)索引,应该指定前缀长度,使用前缀索引。

  (D) 利用最左前缀,创建一个n列的索引时,实际是创建了MySQL可利用的n个索引。可利用索引中的最左边的列集来匹配行,这样的列集被称为最左前缀。

  (E) 不要过度索引,

  (F) 对于InnoDB存储引擎的表,记录默认先后会以 主键、唯一索引、内部列 依次存放,选择好的主键很重要。同时,普通索引会保存主键的键值,主键要尽可能选择短的数据类型。

三、BTREE索引和HASH索引

  (A) HASH索引的特点:

    只用于=和<=>操作符的等式比较。

    优化器不能使用HASH索引来加速ORDER BY 操作。

    MySQL不能确定两个值之间大约有多少行。

    只能使用整个关键词来搜索一行。

  (B) BTREE索引的特点

    使用 >、<、>=、<=、BETWEEN、!=或者<>,或者LIKE 'pattern‘(不以通配符开始)操作符时,都可以使用索引。

四、小结

  大多数MySQL索引使用BTREE中存储,空间列类型的索引使用RTREE。