【mysql】查询性能优化
来源:互联网 发布:网络社会组织 编辑:程序博客网 时间:2024/05/28 03:03
mysql执行查询,客户端向mysql发送请求的时候,mysql服务器执行一系列过程,保证查询语句在mysql中得到最高性能的效率。
1、客户端发送一条查询给服务器
2、服务器先检查查询缓存,如果命中了缓存,则返回存储在缓存中的结果。否则,进入下一个阶段。
3、服务器进行sql解析、预处理,再由优化器生成对应的执行计划
4、mysql根据优化器生成的执行计划,调用存储引擎的API来执行查询
5、返回结果给客户端
当然,如果客户端发送的sql语句已经是优化过的,那么执行效率更高,下面介绍几种特定类型的优化:
①COUNT()查询
COUNT函数可以统计某个列值的数量,也可以统计行数;在统计列值时不统计NULL值。经试验,COUNT(*)的性能比括号内指定一个列的性能更好。
使用COUNT时的常见错误:在括号内指定一个列却希望统计结果集的行数。因此统计结果集的行数时,最好使用COUNT(*),这样意义清晰,而且性能更好。
②关联查询
如无其他理由,需要在关联顺序中的第二张表(及之后)的相应列上创建索引。
③子查询
关于子查询最好的优化建议是尽可能使用关联查询代替
④UNION查询
除非确实需要服务器消除重复行,否则一定要用UNION ALL
⑤其他查询
例如GROUP BY、DISTINCT、LIMIT等查询时,创建对应的索引,效率会不错。
阅读全文
0 0
- mysql查询性能优化
- mysql性能优化(查询)
- MySQL查询性能优化
- mysql查询性能优化
- mysql查询性能优化
- [MySQL]--查询性能优化
- MySQL 查询性能优化
- 【mysql】查询性能优化
- mysql 查询性能优化
- MySql查询性能优化
- mysql查询性能优化
- Mysql性能优化-查询优化
- MySQL查询的性能优化
- MySQL查询的性能优化
- MySQL查询的性能优化
- MySQL查询的性能优化
- MySQL查询的性能优化
- MySQL查询的性能优化
- activemq group分组
- 关于windows下QT5.X编译mysql后找不到生成文件的问题
- Python数据分析基础(三)——pandas
- codeforces544E
- 一次无锁循环队列的编写回顾
- 【mysql】查询性能优化
- 补补嵌入式系统基础知识
- 排序算法
- jass 重置英雄
- Python数据分析基础(四)——数据文件处理
- 你要知道的游戏开发新手入门指南
- springmvc 整合 swagger2
- Generate Parentheses
- 端口分类调研