MySQL查询优化系列之MySQL查询优化器

此文章主要向大家描述的是MySQL查询优化系列之MySQL查询优化器,当你在对一查询进行提交的时候,MySQL数据库会对它进行分析,主要是看其是否可以用来做一些优化使处理该查询的速度更快。

这一部分将介绍查询优化器是如何工作的。如果你想知道MySQL(和PHP搭配之***组合)采用的优化手段,可以查看MySQL(和PHP搭配之***组合)参考手册。

当然,MySQL(和PHP搭配之***组合)查询优化器也利用了索引,但是它也使用了其它一些信息。例如,如果你提交如下所示的查询,那么无论数据表有多大,MySQL(和PHP搭配之***组合)执行它的速度都会非常快:

 
 
 
  1. SELECT * FROM tbl_name WHERE 0; 

在这个例子中,MySQL(和PHP搭配之***组合)查看WHERE子句,认识到没有符合查询条件的数据行,因此根本就不考虑搜索数据表。你可以通过提供一个EXPLAIN语句看到这种情况,这个语句让MySQL(和PHP搭配之***组合)显示自己执行的但实际上没有真正地执行的SELECT查询的一些信息。如果要使用EXPLAIN,只需要在EXPLAIN单词放在SELECT语句的前面:

 
 
 
  1. MySQL(和PHP搭配之***组合)> EXPLAIN SELECT * FROM tbl_name WHERE 0\G  
  2. id: 1  
  3. select_type: SIMPLE  
  4. table: NULL  
  5. type: NULL  
  6. possible_keys: NULL  
  7. key: NULL  
  8. key_len: NULL  
  9. ref: NULL  
  10. rows: NULL  
  11. Extra: Impossible WHERE  
  12.  

通常情况下,EXPLAIN返回的信息比上面的信息要多一些,还包括用于扫描数据表的索引、使用的联结类型、每张数据表中估计需要检查的数据行数量等非空(NULL)信息。

优化器是如何工作的

MySQL(和PHP搭配之***组合)查询优化器有几个目标,但是其中最主要的目标是尽可能地使用索引,并且使用最严格的索引来消除尽可能多的数据行。你的最终目标是提交SELECT语句查找数据行,而不是排除数据行。

优化器试图排除数据行的原因在于它排除数据行的速度越快,那么找到与条件匹配的数据行也就越快。如果能够首先进行最严格的测试,查询就可以执行地更快。假设你的查询检验了两个数据列,每个列上都有索引:

 
 
 
  1. SELECT col3 FROM mytable  
  2. WHERE col1 = ’some value’ AND col2 = ’some other value’; 

假设col1上的测试匹配了900个数据行,col2上的测试匹配了300个数据行,而同时进行的测试只得到了30个数据行。先测试Col1会有900个数据行,需要检查它们找到其中的30个与col2中的值匹配记录,其中就有870次是失败了。

先测试col2会有300个数据行,需要检查它们找到其中的30个与col1中的值匹配的记录,只有270次是失败的,因此需要的计算和磁盘I/O更少。其结果是,优化器会先测试col2,因为这样做开销更小。

以上的相关内容就是对MySQL查询优化系列讲座之查询优化器的介绍,望你能有所收获。

【编辑推荐】

  1. MySQL AUTO_INCREMENT的正确用法
  2. MySQL数据库在linux下远程的连接错误
  3. MySQL5中的字符集问题与破解方案
  4. MySQL数据库与表的最基本命令大盘点
  5. MySQL全文搜索索引的字段作用

名称栏目:MySQL查询优化系列之MySQL查询优化器
文章链接:http://www.shufengxianlan.com/qtweb/news44/458794.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联