标签:空间 搜索 先后 att 使用 开始 ash 字符 限制
一、索引可以有效地提升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。
标签:空间 搜索 先后 att 使用 开始 ash 字符 限制
原文地址:http://www.cnblogs.com/TwoWaterLee/p/6106763.html