高性能的MySQL(6)查询执行机制(一)
希望优化查询性能的时候,最好的办法是弄清楚MySQL是如何优化和执行查询的。了解了内部机制,才能更好的实施设计。
当MySQL执行一个查询时,到底做了什么,先看一副图吧: 1、客户端发送一条查询给服务器。 2、服务器先检查查询缓存,如果命中了缓存,则立刻返回缓存中的结果,否则进入下一步。 3、服务器端进行SQL解析、预处理、再由优化器生成对应的执行计划。 4、MySQL根据优化器生成的执行执行计划,调用存储引擎的API来进行查询。 5、将结果返回给客户端 上面的每一步都很复杂,特别是查询优化器这部分,接下来介绍每一个步骤的具体内容。 1、客户端/服务器通信协议 MySQL客户端和服务端之间的通信协议是“半双工”的,意思是在任何一个时刻,要么是由服务端向客户端发送数据,要么是客户端向服务器发送数据,这2个动作不能同时发生。一旦一端开始发生消息,另一端要接收完整个消息才能响应对方。 客户端用一个单独的数据包传给服务器,这也是为什么当查询的语句很长的时候,参数max_allowed_packet就特别重要了,服务器会拒绝太大的数据抛出相应错误。 相反的,服务器给客户端是数据一般比较多,由多个数据包组成,这也是为什么查询时必须加上LIMIT限制的原因。 多数连接MySQL的库函数都可以获得全部结果集并缓存到内存中,默认一般是获得全部结果集并缓存在内存中。但是如果需要返回一个很大的结果集,这样做并不好,因为库函数会花费很多时间来存储所有结果集,但是这样也会在客户端交互的整个过程一直占用服务器资源。 我们举例PHP来说明一下: <?php $link = mysql_connect('localhost','root','123456'); $result = mysql_query('select * from emp',$link); while($row = mysql_fetch_array($result)){ //do something } (编辑:徐州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |