iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >php mysql慢查询是什么意思
  • 180
分享到

php mysql慢查询是什么意思

2023-06-25 14:06:59 180人浏览 泡泡鱼
摘要

这篇文章主要为大家展示了“PHP mysql慢查询是什么意思”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php Mysql慢查询是什么意思”这篇文章吧。php mysql慢查询是指在日志中记录

这篇文章主要为大家展示了“PHP mysql慢查询是什么意思”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php Mysql慢查询是什么意思”这篇文章吧。

php mysql慢查询是指在日志中记录运行比较慢的sql语句,而开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

本文操作环境:windows7系统、PHP7.1版、DELL G3电脑

php mysql慢查询是什么?

MySQL慢查询就是在日志中记录运行比较慢的SQL语句,这个功能需要开启才能用。

简介

开启慢查询日志,可以让 MySQL 记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

参数介绍

slow_query_log 慢查询开启状态

slow_query_log_file 慢查询日志存放的位置(这个目录需要 MySQL 的运行帐号的可写权限,一般设置为 MySQL 的数据存放目录)

long_query_time 查询超过多少秒才记录,默认是 10 秒

开启慢查询

(1) 查看慢查询相关参数

mysql> show variables like 'slow_query%';+---------------------------+-----------------------------------+| Variable_name             | Value                              |+---------------------------+-----------------------------------+| slow_query_log            | OFF                                || slow_query_log_file       | /usr/local/var/mysql/slow.log          |+---------------------------+-----------------------------------+mysql> show variables like 'long_query_time';+-----------------+-----------+| Variable_name   | Value     |+-----------------+-----------+| long_query_time | 10.000000 |+-----------------+-----------+

(2)设置方法

方法一:全局变量设置

将 slow_query_log 全局变量设置为 “ON” 状态

mysql> set global slow_query_log='ON';

设置慢查询日志存放的位置

mysql> set global slow_query_log_file='/usr/local/var/mysql/slow.log ';

设置慢查询时间,查询超过 1 秒就记录

mysql> set global long_query_time=1;

方法二:配置文件设置

修改配置文件 my.cnf,在 [mysqld] 下的下方加入

[mysqld]slow_query_log = ONslow_query_log_file = /usr/local/var/mysql/slow.log long_query_time = 1

(3)重启 MySQL 服务

service mysqld restart

(4)慢查询日志分析

截取一段慢查询日志:

# Time: 180918 19:06:21# User@Host: proxy[proxy] @  [192.168.0.16]  Id: 6707197# Query_time: 1.015429  Lock_time: 0.000116 Rows_sent: 1  Rows_examined: 44438SET timestamp=1537268781;select        id, user_id, device_uuid, bd_client_id, bd_user_id, bd_tag,        nodisturb_mode, nodisturb_start_time,        nodisturb_end_time, binding_time, device_os_type, app_type, state        from app_mobile_device        where user_id = '78436'            and app_type = 'YGY'        order by binding_time desc;# User@Host: proxy[proxy] @  [192.168.0.16]  Id: 6707236# Query_time: 1.021662  Lock_time: 0.000083 Rows_sent: 1  Rows_examined: 44438SET timestamp=1537268781;select        id, user_id, device_uuid, bd_client_id, bd_user_id, bd_tag,        nodisturb_mode, nodisturb_start_time,        nodisturb_end_time, binding_time, device_os_type, app_type, state        from app_mobile_device        where user_id = '14433'            and app_type = 'YGY'        order by binding_time desc;

这里可以看到:

Query_time (慢查询语句的查询时间) 都超过了设置的 1s,

Rows_sent (慢查询返回记录) 这里只返回了 1 条

Rows_examined (慢查询扫描过的行数) 44438 -> 通过这里大概可以看出问题很大

现在将这个 SQL 语句放到数据库去执行,并使用 EXPLaiN 分析 看下执行计划

EXPLAIN                                select                                         id, user_id, device_uuid, bd_client_id, bd_user_id, bd_tag,                                nodisturb_mode, nodisturb_start_time,                                  nodisturb_end_time, binding_time, device_os_type, app_type, state                                  from app_mobile_device                                 where user_id = '78436'                                        and app_type = 'YGY'                               order by binding_time desc;

查询结果是:

php mysql慢查询是什么意思

解释下参数:

php mysql慢查询是什么意思

这里可以发现:rows 为查询的行数,查询了 4w 多行,那慢是肯定的了。

因为这里是好几个条件,并且没有使用一个索引,那就只能给添加索引了,

这里给选择添加普通多列索引,因为这个表在最开始设计出问题了,导致有重复的数据,不能设置唯一索引了。

ALTER  TABLE  app_mobile_device  ADD  INDEX user_app_type_only (  `user_id` ,`app_type` )

索引设置了,再看下刚的 SQL 的执行计划。

php mysql慢查询是什么意思

可以发现 rows 的检查行数,很明显的下降了。

到此,慢查询的使用和优化就基本完成了。

以上是“php mysql慢查询是什么意思”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: php mysql慢查询是什么意思

本文链接: https://www.lsjlt.com/news/305252.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • php mysql慢查询是什么意思
    这篇文章主要为大家展示了“php mysql慢查询是什么意思”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php mysql慢查询是什么意思”这篇文章吧。php mysql慢查询是指在日志中记录...
    99+
    2023-06-25
  • mysql的内外查询是什么意思
    这篇文章主要介绍mysql的内外查询是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql的内查询是通过设置连接条件的方式,利用条件表达式来消除交叉连接的某些数据行,查询...
    99+
    2024-04-02
  • MySQL的慢查询是什么
    这篇文章主要讲解了“MySQL的慢查询是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的慢查询是什么”吧!MySQL慢查询分析 在我...
    99+
    2024-04-02
  • mysql慢查询指的是什么
    这篇文章将为大家详细讲解有关mysql慢查询指的是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。MySQL慢查询就是在日志中记录运行比较慢的SQL语句,这个功能需要开...
    99+
    2024-04-02
  • mysql慢查询日志是什么
    这篇文章将为大家详细讲解有关mysql慢查询日志是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。定义:mysql提供的一种记录日志的功能,用来记录mysql相应时间超...
    99+
    2024-04-02
  • MySQL的查询缓存机制是什么意思
    本篇内容主要讲解“MySQL的查询缓存机制是什么意思”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL的查询缓存机制是什么意思”吧!  查询必须是完全相同...
    99+
    2024-04-02
  • mysql中逻辑查询处理是什么意思
    这篇文章给大家分享的是有关mysql中逻辑查询处理是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。 查询处理可以分为逻辑查询处理和物理查询处理...
    99+
    2024-04-02
  • MySQL慢日志的意思是什么
    这篇文章主要介绍“MySQL慢日志的意思是什么”,在日常操作中,相信很多人在MySQL慢日志的意思是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL慢日志的意思是...
    99+
    2024-04-02
  • MySQL中慢查询指的是什么
    这篇文章主要介绍MySQL中慢查询指的是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!分析MySQL语句查询性能的方法除了使用EXPLAIN输出执行计划,还可以让MySQL记录下...
    99+
    2024-04-02
  • mysql慢日志查询的方法是什么
    要查询MySQL慢日志,可以使用以下方法: 登录到MySQL数据库管理系统。 运行以下SQL查询语句来查看慢查询日志的参数设...
    99+
    2024-03-14
    mysql
  • ip查询显示泛播是什么意思?
    文章目录 背景ip泛播是什么Cloudflare 进行泛播 背景 好奇openai的请求是如何转发的。 ip泛播是什么 查询这个ip是个泛播 Cloudflare 进行泛播 如...
    99+
    2023-09-07
    tcp/ip 网络 服务器
  • mysql慢查询优化的方法是什么
    MySQL慢查询优化的方法有以下几种:1. 使用索引:索引可以大大提高查询的速度。需要根据查询语句的特点选择合适的列进行索引,避免全...
    99+
    2023-08-31
    mysql
  • mysql中慢查询日志指的是什么
    这篇文章给大家分享的是有关mysql中慢查询日志指的是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、介绍用于记录执行时间超过某个临界值的SQL日志,用于快速定位慢速查询,供我们优化参考。2、开启方法打开慢...
    99+
    2023-06-15
  • MySQL中慢查询记录的原理是什么
    本篇文章给大家分享的是有关MySQL中慢查询记录的原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 一、慢查询中的时间 实际...
    99+
    2024-04-02
  • redis慢查询指的是什么
    这篇文章将为大家详细讲解有关redis慢查询指的是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。redis慢查询指的是命令执行时长比较长的查询,其慢查询日志就是Red...
    99+
    2024-04-02
  • php是什么意思
    PHP是一种通用开源脚本语言,与C语言类似,是常用的网站编程语言,随着移动应用的兴起,也可用于开发API接口,几乎支持所有流行的数据库以及操作系统,PHP 语言作为当今热门的网站程序开发语言,它具有成本低、速度快、可移植性好、内置丰富的函数...
    99+
    2024-04-02
  • mysql 是什么意思
    MySQL是一种开源的关系型数据库管理系统(RDBMS),它是由瑞典MySQL AB公司开发的,现在属于Oracle公司。MySQL...
    99+
    2023-09-05
    mysql
  • mysql是什么意思
    mysql是开源关系型数据库管理系统,特点是开源、可靠、可扩展、性能优异和面向社区。其用途广泛,包括存储web应用程序数据、管理电子商务数据、建立数据仓库、支持内容管理系统和本地移动应用...
    99+
    2024-04-02
  • 为什么MySQL查询速度会慢
    目录一、先了解一下mysql查询的执行过程二、是否查询了不需要的数据三、衡量查询开销的几个重要指标1、响应时间2、扫描的行数和返回的行数3、扫描的行数和访问类型4、一般可以通过explain的Extra列查看查询的优劣一...
    99+
    2022-12-01
    mysql查询缓慢原因 MySQL慢查询及解决方案 mysql慢查询优化
  • MySQL开启慢查询日志的方法是什么
    小编给大家分享一下MySQL开启慢查询日志的方法是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.1 简介开启慢查询日志,...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作