MySQL如何盘查此刻正在运行的SQL语句
作者:数据库学习更新于:
2015-10-29 09:28:08
下面,小编的数据库学习助手将跟大家分享MySQL如何查询当前正在运行的SQL语句的内容,想了解的朋友赶紧来看一下吧!
SQL即结构化查询语言(Structured Query Language),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。SQL语句无论是种类还是数量都是繁多的,很多语句也是经常要用到的,SQL查询语句就是一个典型的例子,无论是高级查询还是低级查询,SQL查询语句的需求是最频繁的。
通过status命令,查看Slow queries这一项,如果值长时间>0,说明有查询执行时间过长
以下是引用片段:
MySQL> status; -------------- mysql Ver 11.18 Distrib 3.23.58, for redhat-Linux-gnu (i386) Connection id: 53 Current database: (null) Current user: root@localhost Current pager: stdout Using outfile: '' Server version: 5.0.37-log Protocol version: 10 Connection: Localhost via Unix socket Client characterset: latin1 Server characterset: latin1 UNIX socket: /tmp/mysql.sock Uptime: 4 days 16 hours 49 min 57 sec Threads: 1 Questions: 706 Slow queries: 0 Opens: 177 Flush tables: 1 Open tables: 52 Queries per second avg: 0.002 --------------
|
这时再通过show processlist命令来查看当前正在运行的SQL,从中找出运行慢的SQL语句,找到执行慢的语句后,再用explain命令查看这些语句的执行计划。
mysql> show processlist;
+----+------+-----------+------+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+------+-----------+------+---------+------+-------+------------------+
| 53 | root | localhost | NULL | Query | 0 | NULL | show processlist |
+----+------+-----------+------+---------+------+-------+------------------+
![](/Public/images/upload/article/2015-10/56317511e2988.jpg)
内容简单易懂,大家不妨去试一下。更多相关的数据库教程视频,可前往课课家官方网。