MySQL 数据库Query 的优化.docx

MySQL 数据库Query 的优化.docx

ID:61513064

大小:1.45 MB

页数:44页

时间:2021-02-09

MySQL 数据库Query 的优化.docx_第1页
MySQL 数据库Query 的优化.docx_第2页
MySQL 数据库Query 的优化.docx_第3页
MySQL 数据库Query 的优化.docx_第4页
MySQL 数据库Query 的优化.docx_第5页
资源描述:

《MySQL 数据库Query 的优化.docx》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、MySQL数据库Query的优化MySQL的QueryOptimizerMySQLQueryOptimizer是什么?在MySQL中有一个专门负责优化SELECT语句的优化器模块,我们将要重点分析的MySQLOptimizer,其主要的功能就是通过计算分析系统中收集的各种统计信息,为客户端请求的Query给出他认为最优的执行计划,也就是他认为最优的数据检索方式。当MySQLOptimizer接收到从QueryParser(解析器)送过来的Query之后,会根据MySQLQuery语句的相应语法对该Query进行分解分析的同时,还会做很多其他的计算转化工作。如常量转

2、化,无效内容删除,常量计算等等。所有这些工作都只为了Optimizer工作的唯一目的,分析出最优的数据检索方式,也就是我们常说的执行计划。MySQLQueryOptimizer基本工作原理在分析MySQLOptimizer的工作原理之前,先了解一下MySQL的QueryTree。MySQL的QueryTree是通过优化实现DBXP的经典数据结构和Tree构造器而生成的一个指导完成一个Query语句的请求所需要处理的工作步骤,我们可以简单的认为就是一个的数据处理流程规划,只不过是以一个Tree的数据结构存放而已。通过QueryTree我们可以很清楚的知道一个Quer

3、y的完成需要经过哪些步骤的处理,每一步的数据来源在哪里,处理方式是怎样的。在整个DBXP的QueryTree生成过程中,MySQL使用了LEX和YACC这两个功能非常强大的语法(词法)分析工具。MySQLQueryOptimizer的所有工作都是基于这个QueryTree所进行的。各位读者朋友如果对MySQLQueryTree实现生成的详细信息比较感兴趣,可以参考ChalesA.Bell的《ExpertMySQL》这本书,里面有比较详细的介绍。MySQLQueryOptimizer并不是一个纯粹的CBO(CostBaseOptimizer),而是在CBO的基础上增

4、加了一个被称为HeuristicOptimize(启发式优化)的功能。也就是说,MySQLQueryOptimizer在优化一个Query选择出他认为的最优执行计划的时候,并不一定完全按照系数据库的元信息和系统统计信息,而是在此基础上增加了某些特定的规则。其实我个人的理解就是在CBO的实现中增加了部分RBO(RuleBaseOptimizer)的功能,以确保在某些特别的场景下控制Query按照预定的方式生成执行计划。当客户端向MySQL请求一条Query,到命令解析器模块完成请求分类区别出是SELECT并转发给QueryOptimizer之后,QueryOptim

5、izer首先会对整条Query进行,优化处理掉一些常量表达式的预算,直接换算成常量值。并对Query中的查询条件进行简化和转换,如去掉一些无用或者显而易见的条件,结构调整等等。然后则是分析Query中的Hint信息(如果有),看显示Hint信息是否可以完全确定该Query的执行计划。如果没有Hint或者Hint信息还不足以完全确定执行计划,则会读取所涉及对象的统计信息,根据Query进行写相应的计算分析,然后再得出最后的执行计划。QueryOptimizer是一个数据库软件非常核心的功能,虽然在这里说起来只是简单的几句话,但是在MySQL内部,QueryOptim

6、izer实际上是经过了很多复杂的运算分析,才得出最后的执行计划。对于MySQLQueryOptimizer更多的信息,可以通过MySQLInternal文档进行更为全面的了解。Query语句优化基本思路和原则在分析如何优化MySQLQuery之前,我们需要先了解一下Query语句优化的基本思路和原则。一般来说,Query语句的优化思路和原则主要提现在以下几个方面:1.优化更需要优化的Query;2.定位优化对象的性能瓶颈;3.明确的优化目标;4.从Explain入手;5.多使用profile6.永远用小结果集驱动大的结果集;7.尽可能在索引中完成排序;8.只取出自

7、己需要的Columns;9.仅仅使用最有效的过滤条件;10.尽可能避免复杂的Join和子查询;上面所列的几点信息,前面4点可以理解为Query优化的一个基本思路,后面部分则是我们优化中的基本原则。下面我们先针对Query优化的基本思路做一些简单的分析,理解为什么我们的Query优化到底该如何进行。优化更需要优化的Query为什么我们需要优化更需要优化的Query?这个地球人都知道的“并不能成为问题的问题”我想就并不需要我过多解释吧那什么样的Query是更需要优化呢?对于这个问题我们需要从对整个系统的影响来考虑。什么Query的优化能给系统整体带来更大的收益,就更需

8、要优化。一

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。