博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 处理查询请求过程
阅读量:6680 次
发布时间:2019-06-25

本文共 1027 字,大约阅读时间需要 3 分钟。

需要搞清楚查询为什么会慢,就要搞清楚mysql处理查询请求的过程:

1.客户端发送SQL请求给服务器

2.服务器检查是否可以在查询缓存中命中该SQL

 

查询缓存对SQL性能的影响。

1.需要对缓存加锁。

2.表更新需要对缓存刷新。

 

对于读写频繁的系统使用查询缓存可能会降低查询的处理效率,在这种情况下不要使用查询缓存。

 

query_cache_type :设置查询是否可用

值为:on,off,demand 。

demand 表示只有在查询语句中使用SQL_CACHE和SQL_NO_CACHE 来控制是否需要缓存。

query_cache_size 设置查询缓存内存的大小

query_cache_limit 设置查询缓存可用出错的最大值,如果知道结果比较大可以在sql语句加上 SQL_NO_CAHCE提示字 不进行缓存,提高效率。

query_cache_wlock_invalidate 设置数据表被锁后是否返回缓存中的数据,默认是关闭的。

query_cache_min_res_unit 设置查询缓存分配的内存快的最小单位。

 

 

3.服务器端进行SQL解析,预处理,再由优化器生成对应的执行计划

 

这个阶段包括多个子过程:

解析SQL,预处理,优化SQL执行计划

3.1会造成MYSQL生成错误执行计划的原因:

1.统计信息不准确

2.执行计划中的成本估算不等于实际执行计划的成本。

mysql 服务器层不知道哪些页面在内存中,哪些在磁盘上,哪些需要顺序读取,哪些页面需要随机读取。

3.mysql优化器所认为的最优可能与你认为的最优不一样。mysql 是基于成本模型选择最优的执行计划。

4.mysql 不考虑其他并发查询,这可能会影响当前查询的速度。

5.mysql 有时也会基于一些固定的规则来生成执行计划。

6.mysql 不会考虑不受其控制的成本。

  存储过程,用户自定义函数

3.2mysql 优化器可优化的SQL类型

1.重新定义表的关联顺序。

优化器会根据统计信息来决定表的关联顺序。

2. 将外链接转化成内连接

3.使用等价变换规则。

     5=5 and a>5 改写为 a>5.

4.优化 count() ,min(),max()

5.子查询优化

6.提前终止查询

例如:

select * from user where 1!=1;

7.对IN条件进行优化。

 

4.根据执行计划,调用存储引擎API来查询数据。

5.将结果返回到客户端。

转载地址:http://nqnao.baihongyu.com/

你可能感兴趣的文章
Node实现简单的注册时后端的MVC模型架构
查看>>
git使用笔记---简单入门
查看>>
在Xcode中使用pch文件
查看>>
[CF983E]NN country
查看>>
POJ 3533 Light Switching Game(三维Nim积)题解
查看>>
GPGPU报告
查看>>
Android测试分析3
查看>>
mysql导入导出命令
查看>>
软件体系结构C2风格
查看>>
双外边距浮动bug;3像素文本偏移bug;IE6以下相对定位中的绝对定位bug
查看>>
【实习记】2014-08-23网络安全XSS与CSRF总结
查看>>
如何写出让人看了恶心的代码
查看>>
http状态码
查看>>
好记性不如烂笔杆-android学习笔记<十五> GridView简单用法
查看>>
最短路径
查看>>
表格相关技巧(双击启动事件、取得行号、定义表格的读写属性)
查看>>
ubuntu server vsftpd 虚拟用户及目录
查看>>
GCD多线程使用
查看>>
[转载] 格式化字符串漏洞原理介绍
查看>>
python小项目之微信远程控制
查看>>