者是这些类型的部分(比如,利用最左边前缀)时发生。对于之前的表的每一个行联合,全部记录都将从表中读出。这个类型严重依赖于根据索引匹配的记录多少—越少越好
range
这个连接类型使用索引返回一个范围中的行,比如使用>或
FAQ
1
表中包含 10 万条记录,有一个 datetime 类型的字段。
取数据的语句:
SELECT * FROM my_table WHERE created_at < '2010-01-20';
用 EXPLAIN 检查,发现 type 是 ALL, key 是 NULL,根本没用上索引。
可以确定的是,created_at 字段设定索引了。
什么原因呢?
用 SELECT COUNT(*) 看了一下符合 WHERE 条件的记录总数,居然是 6W 多条!!
难怪不用索引,这时用索引毫无意义,就好像 10 万条记录的用户表,有个性别字段,不是男就是女,在这种字段设置索引是错误的决定。
稍微改造一下上述语句:
SELECT * FROM my_table WHERE created_at BETWEEN '2009-12-06' AND '2010-01-20';
这回问题解决!
符合条件的记录只有几百条,EXPLAIN 的 type 是 range,key 是 created_at,Extra 是 Using where 。
自己总结个准则,索引的目的就是尽量缩小结果集,这样才能做到快速查询。
6万条记录符合条件,已经超出总记录数的一半,这时索引已经没有意义了,因此 MySQL 放弃使用索引。
这与设置 gender 字段,并加上索引的情况相似,当你要把所有男性记录都选取出来,符合条件的记录数约占总数的一半,MySQL 同样不会使用这个索引。
唯一值越多的字段,使用索引的效果越好。
设置联合索引时,唯一值越多的,越应该放在“左侧”。
您可能感兴趣的文章: MySQL 创建索引(Create Index)的方法和语法结构及例子
mysql 添加索引 mysql 如何创建索引
MySQL 主键与索引的联系与区别分析
mysql占用CPU过高的解决办法(添加索引)
MYSQL索引无效和索引有效的详细介绍
基于mysql全文索引的深入理解
Mysql索引会失效的几种情况分析
mysql索引失效的五种情况分析 QQ空间新浪微博腾讯微博搜狐微博人人网开心网百度搜藏更多0 Tags:Mysql建表索引 复制链接收藏本文打印本文关闭本文返回首页 上一篇:MySQL中批量删除指定前缀表的sql语句 下一篇:MySql insert插入操作的3个小技巧分享
|