-%3erow mysql_MySQL查询优化

# MySQL查询优化

* [请简述项目中优化MySQL语句执行效率的方法,从哪些方面入手,SQL语句性能如何分析?](https://www.kancloud.cn/ranjun940726/php_interview/596348#MySQLSQL_3)

* [分析查询速度](https://www.kancloud.cn/ranjun940726/php_interview/596348#_5)

* [优化查询过程中的数据访问](https://www.kancloud.cn/ranjun940726/php_interview/596348#_74)

* [优化长难的查询语句](https://www.kancloud.cn/ranjun940726/php_interview/596348#_93)

* [优化特定类型的查询语句](https://www.kancloud.cn/ranjun940726/php_interview/596348#_106)

* [优化`count()`查询](https://www.kancloud.cn/ranjun940726/php_interview/596348#count_108)

* [优化关联查询](https://www.kancloud.cn/ranjun940726/php_interview/596348#_118)

* [优化子查询](https://www.kancloud.cn/ranjun940726/php_interview/596348#_124)

* [优化`group by`和`distinct`](https://www.kancloud.cn/ranjun940726/php_interview/596348#group_bydistinct_127)

* [优化`limit`子句](https://www.kancloud.cn/ranjun940726/php_interview/596348#limit_134)

* [优化`union`](https://www.kancloud.cn/ranjun940726/php_interview/596348#union_142)

# 请简述项目中优化MySQL语句执行效率的方法,从哪些方面入手,SQL语句性能如何分析?

# 分析查询速度

* 记录慢查询日志

分析查询日志,使用`pt-query-digest`工具进行分析

* 使用`show profile`

set profiling=1; # 服务器上执行的所有语句会检测消耗的时间、存到临时表中

`show profiles # 所有的SQL语句执行记录`

`show profile for query 临时表ID # 查执行ID的SQL语句`

~~~

mysql> set profiling=1;

Query OK, 0 rows affected

mysql> select * from user;

+----+------+-----+

| id | name | age |

+----+------+-----+

| 1 | Jack | 23 |

+----+------+-----+

1 row in set

mysql> show profiles;

+----------+------------+---------------------------------------------------------------------------------------------------------------------------------+

| Query_ID | Duration | Query |

+----------+------------+---------------------------------------------------------------------------------------------------------------------------------+

| 1 | 8.675E-5 | set profiling=1 |

| 2| 0.000197 | select * from user |

+----------+------------+---------------------------------------------------------------------------------------------------------------------------------+

10 rows in set

mysql> show profile for query 2;

+----------------------+----------+

| Status | Duration |

+----------------------+----------+

| starting | 4.3E-5 |

| checking permissions | 7E-6 |

| Opening tables | 1.8E-5 |

| System lock | 1E-5 |

| init | 1.4E-5 |

| optimizing | 4E-6 |

| statistics | 3.1E-5 |

| preparing | 1E-5 |

| executing | 2E-6 |

| Sending data | 1E-5 |

| end | 3E-6 |

| query end | 2E-6 |

| closing tables | 5E-6 |

| freeing items | 3.5E-5 |

| logging slow query | 3E-6 |

| cleaning up | 2E-6 |

+----------------------+----------+

16 rows in set

~~~

* show status

`show status`会返回一些计数器,`show global status`查看服务器级别的所有计数。

* show processlist

观察是否有大量的线程处于不正常的状态或特征。

* explain

分析单条的SQL语句

~~~

mysql> explain select * from user;

+----+-------------+-------+--------+---------------+------+---------+------+------+-------+

| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |

+----+-------------+-------+--------+---------------+------+---------+------+------+-------+

| 1 | SIMPLE | user | system | NULL | NULL | NULL | NULL | 1 | |

+----+-------------+-------+--------+---------------+------+---------+------+------+-------+

1 row in set

~~~

> explain它有一个别名`desc`,所以使用`desc select * from user;`查询到的结果与上面的一样。

# 优化查询过程中的数据访问

* 数据太多会导致查询性能下降。

* 确定应用程序是否在检索大量超过需要的数据,可能太多行或列。

* 确认MySQL服务器是否在分析大量不必要的数据行

**避免使用以下SQL语句**

* 查询不需要的记录,使用`limit`解决

* 多表管理返回全部列,需要制定列,[如A.id](http://xn--a-ch1b.id/)、B.name等

* 总是取出全部列,`select *`会让优化器无法完成索引覆盖扫描优化

* 重复查询相同的数据,可以使用缓存,下次直接读取缓存

**是否在扫描额外的记录**

使用`explain`来进行分析,如果发现查询需要扫描大量的数据但是只返回少数的行,可以通过如下技巧去优化:

* 使用索引覆盖扫描,把所有的列都放在索引中。

* 改变数据库和表的结构,修改数据表范式

* 重写SQL语句,让优化器可以以最优的方式执行查询

# 优化长难的查询语句

使用尽可能小的查询是好的,但有时将一个大的查询分解成多个小的查询是很有必要的。

* **切分查询**

将一个大的查询分为多个小的相同的查询

一次性删除1000万的数据比一次删除1万,暂停一会儿在执行删除1万条数据要较少更多的服务器开销。

* **分解关联查询**

可以将一条关联语句分解成多个SQL语句执行

让缓存的效率更高

执行单个查询可以减少锁的竞争

在应用层做关联可以更容易对数据库进行拆分

# 优化特定类型的查询语句

## 优化`count()`查询

* `count(*)`占用的`*`会忽略所有的列,直接统计所有的列数,因此不要使用`count(列名)`

* MyISAM中`没有任何where条件的count(* )`查询速度非常快

* `有where条件`时,MyISAM的count统计不一定比其他表引擎快

优化:

* 可以使用`explain`查询近似值,用近似值代替`count(*)`

* 增加汇总表

* 使用缓存

## 优化关联查询

* 确定on或者using子句的列上有索引;

* 确保`group by`和`order by`中只有一个表中的列,这样MySQL才有可能使用索引;

## 优化子查询

尽量使用关联查询替代

## 优化`group by`和`distinct`

* 使用**索引**来优化

* 关联查询中,使用**标识列**(主键列)进行分组的效率会更高

* 如果不需要`order by`,进行`group by`时使用`order by NULL`,MySQL不会进行文件排序

* `with rollup`超级剧和,可以挪到应用程序处理

## 优化`limit`子句

`limit`偏移量大的时候,查询效率较低。

方案:

* 记录上一次查询的最大ID,下次查询时直接根据ID来查询(还是使用limit查询,不过加一个where条件,id > ID)

## 优化`union`

`union all`的效率高于`union`。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/346771.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

apache karaf_Apache Karaf遇到Apache HBase

apache karaf介绍 Apache HBase是一个以Google Bigtable为蓝本的开源,分布式,版本化,面向列的商店。 如果您是普通读者,那么您可能已经知道Apache Karaf是什么,但是对于那些不是的读者:Apache Karaf是一个O…

mysql5.6特性_MySQL5.6新版本特性

MySQL已发布新的系列版本5.6.x,如果打算升级的朋友可以尝试,虽然目前没有收到新版本的使用反馈,但凭借MySQL占据市场份额来看,新版本的确值得期待。五大特性:优化器的改进MySQL Optimizer 团队做了大量的工作为了不断的…

实现threadlocal_ThreadLocal如何实现?

实现threadlocal这是我上周的帖子的后续文章,其中我解释了ThreadLocal用法背后的动机 。 从帖子中我们可以回忆起,如果您希望为每个线程拥有一个独立初始化的变量副本,则ThreadLocal确实是一个很酷的概念。 现在,好奇的人可能已经…

mysql timeout的单位_mysql的timeout-阿里云开发者社区

mysql的timeout很多时候我们连接mysql会在timeout这里跌倒,这里明确下mysql的timeout:下面是获取timeout的变量:mysql> show global variables like "%timeout%";---------------------------------------| Variable_name | Val…

带有Spring Boot 2.0的Spring Security:UserDetailsS​​ervice

正如我们在上一篇文章中所看到的,我们的spring应用程序的用户名和密码是通过环境变量配置的。 这对于原型目的是可以的,但是在现实生活中,我们必须提供另一种方式来使用户有资格登录到该应用程序。 为此,我们使用UserDetailsS​​…

java计算整数出现的次数_[剑指offer题解][Java]1到n整数中1出现的次数

前言众所周知,《剑指offer》是一本“好书”。如果你是个算法菜鸡(和我一样),那么最推荐的是先把剑指offer的题目搞明白。对于剑指offer题解这个系列,我的写作思路是,对于看过文章的读者,能够做到…

mysql数据库+ssh框架_SSH框架+Mysql数据库开发java web会员积分消费管理系统

项目描述会员消费管理:会员信息调取查询、会员消费商品添加金额计算、兑换商品等会员管理:会员增删改查积分管理:积分设置、商品积分设置等积分兑换、数据库备份还原、折扣管理、商品管理等运行环境jdk7(8)tomcat7(8)mysql5.7myeclipes或ecli…

spring和spring_Spring交易可见性

spring和spring在初始化应用程序上下文时,Spring在遇到带有Transactional标记的类时会创建代理。 Transactional可以应用于类级别或方法级别。 在类级别应用它意味着该类中定义的所有公共方法都是事务性的。 Spring创建的代理类型,即Jdk代理或CGLIB代理&…

python上传文件到linux服务器_python上传大文件到服务器报错

项目需要,在mac上将打包好的文件(四五百兆)自动上传到web后台,用了两种方式上传,都报了类似的错误,在windows和linux上测试不会报错,但是到了mac打包机上就会报错:①第一种报错:Traceback (most…

mysql 更改root密码及 主机_设置更改root密码(远程,本地)、连接mysql、mysql常用命令...

设置更改root密码1、将mysql加入环境变量中[rootcentos7 ~]# grep mysql /etc/profileexport PATH/usr/local/mysql/bin/:$PATH2、直接登录,无密码[rootcentos7 ~]# mysql -uroot3、方式一:设置密码[rootcentos7 ~]# mysqladmin -uroot password 123456W…

从NetBeans运行和调试WildFly Swarm应用程序

使用NetBeans的Java EE开发人员习惯于直接在NetBeans所选择的应用程序服务器中运行和调试其瘦战应用程序。 在开发打包为ber或镂空jars的微服务时,您期望使用相同的轻松方式进行运行和调试。 好消息是您可以。 在本文中,我将逐步演示如何在NetBeans中运行…

mysql 事实表 维度表_数据库的事实表与维度表

维度表示你要对数据进行分析时所用的一个量,比如你要分析产品销售情况,你可以选择按类别来进行分析,或按区域来分析,这样的按照什么分析就构成一个维度。前面的实例就可以有两个维度:类型和区域。另外每个维度还可以有…

hazelcast入门教程_Hazelcast入门

hazelcast入门教程7月,我写了一个博客向Java开发人员介绍erlang,重点介绍了这两种语言之间的一些异同。 erlang虚拟机具有许多令人印象深刻的内置功能,其中之一是它们独立于位置且可以相互通信。 这意味着可以通过编写很少的代码行在VM之间同…

tcp java实例_实现了基于TCP的Java Socket编程实例代码

实现了基于TCP的Java Socket编程,功能很简单:客户端向服务器端输出一名话"connect",服务器端接收输出到控制台并向客户端输出一名话"Hello",客户端接收并输出。1.服务器端package javase.net.socket;import java.io.Data…

java 批量上传图片插件_java多文件上传plupload控件实现多图片上传(一)

使用的是plupload-2.1.2 控件。网上资源挺多的,很好下载。plupload 官方地址 : http://www.plupload.com/plupload 示例: http://www.plupload.com/examples/plupload Github: https://github.com/moxiecode/plupload整体框架用的是easyui springMVC。1、前台jsp页…

java servlet_Java Servlet的前100个问题

java servlet1)是“ servlets”目录还是“ servlet”目录? 回答: 对于Java Web Server: 在文件系统上,它是“ servlet” c:\ JavaWebServer1.1 \ servlets \ DateServlet.class 在URL路径中,…

精通java ee项目案例_精通JavaEE项目案例

第1章 Java EE开发入门 11.1 基本概念 11.1.1 Java EE API 11.1.2 MVC模型 21.1.3 JSP讨论 31.1.4 Servlet讨论 41.1.5 Model1和Model2 51.2 Eclipse 51.2.1 Eclipse的平台简介 61.2.2 Eclipse的体系结构 61.3 Struts 71.3.1 认识Struts 71.3.2 Strut…

java调用php session_php读取memcahed java session

情景:1:现在有两个系统,一个是Java做的系统,一个是PHP的系统,现在要把两个系统弄成一个单点登录。2:两个系统两个库,两个库的表结构完全不同,现在要解决的就是session共享问题和用户…

[MEGA DEAL]完整的Java编程训练营(94%折扣)

成为Java Master的10门课程(83.5小时):使用JavaFX的设计UI,利用设计模式,Master Multithreading等 嘿,怪胎, 本周,在我们的JCG Deals商店中 ,我们提供了另一个超值优惠…

怎么把java程序放进php_如何在php脚本中执行Java程序?

I have been struggling with this for awhile trying all sorts of options withno results – the file is never created(the file is created with an absolutepath so it’s not being created and Ijust can’t find the file). Does anyonehave any ideas?我认为问题是…