type | 说明 |
---|---|
SYSTEM | 系统,表仅有一行(=系统表)。这是const联接类型的一个特例 |
CONST | 常量,表最多有一个匹配行,因为仅有一行,在这行的列值可被优化器剩余部分认为是常数,const表很快,因为它们只读取一次 |
EQ_REF | 搜索时使用primary key 或 unique类型 |
REF | 根据索引查找一个或多个值 |
INDEX_MERGE | 合并索引,使用多个单列索引搜索 |
RANGE | 对索引列进行范围查找 |
index | 全索引表扫描 |
ALL | 全数据表扫描 |
根据表格可以明显看出,其中const是常量查找,而RANGE是对索引列进行范围查找,所以性能也就很明显的体现了出来。
那使用like查询时,Extra字段代表什么呢?Extra字段中的Using where,又代表什么?
Extra字段
1,Extra字段是Explain输出中也很重要的列,所代表着MySQL查询优化器执行查询的过程中对查询计划的重要补充信息。
2,Extra字段中的Using where意味着mysql服务器将在存储引擎检索行后再进行过滤。所以比起使用使用'='又多了一步查找过程。
显然通过以上的总结我们可以得出结论:当我们使用索引字段进行条件查询时,'='的性能要比like快。
是不是以为到这里就结束了呢?
然而并没有
有的小伙伴该问了那非索引字段呢?
对的,我们下面继续测试非索引字段
EXPLAIN SELECT * FROM crms_customer WHERE customer_name = '张飞'; ----------------------------------- EXPLAIN SELECT * FROM crms_customer WHERE customer_name LIKE '张飞';
除了"="和like同样的两条语句,让我们运行一下:
"=":
like:
可以看出当非索引字段时like和"="是一样的,性能上也没有差别。
(当然,explain中还有很多其他字段,后续我会一一给小伙伴们讲解的。)
结论
经过我们的不懈努力,可以得到结论:当like和"="在使用非索引字段查询时,他们的性能是一样的;而在使用索引字段时,由于"="是直接命中索引的,只读取一次,而like需要进行范围查询,所以"="要比like性能好一些。~~~~
到此这篇关于mysql优化之like和=性能的文章就介绍到这了,更多相关mysql like和=性能内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!