加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

高性能的MySQL(6)查询执行机制(一)

发布时间:2016-08-02 08:42:05 所属栏目:MySql教程 来源:站长网
导读:希望优化查询性能的时候,最好的办法是弄清楚MySQL是如何优化和执行查询的。了解了内部机制,才能更好的实施设计。 当MySQL执行一个查询时,到底做了什么,先看
希望优化查询性能的时候,最好的办法是弄清楚MySQL是如何优化和执行查询的。了解了内部机制,才能更好的实施设计。

当MySQL执行一个查询时,到底做了什么,先看一副图吧:

高性能的MySQL(6)查询执行机制(一)

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
}

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读