专注各种脚本编程
Baidu
加入收藏夹
本站内容有下面分类知识,欢迎您的到来^_^
shell相关:指令篇 基础篇 脚本欣赏 编程实例 shell问问 shell视频教程 技巧篇 水平测试 E文资料 vi编辑器 高级Bash脚本编程指南
其他:mysql perl c语言 oracle
当前位置:| 主页>mysql>

MySQL命令查询当前正在负载运行的SQL语句

百度收藏 QQ搜藏

1)我们先通过status命令查看Mysql运行状态,如下:

  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
  -------------- 
   在上面显示列表的最后一条,我们来查看Slow queries这一项的值,如果多次查看的值大于0的话,说明有些查询sql命令执行时间过长。

   2)这时再通过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 |
+----+------+-----------+------+---------+------+-------+------------------+
    1 row in set (0.00 sec)

上一篇:MySQL top(数据库进程监视工具)安装方法及问题解决 下一篇:结合nmap扫描工具检测MySQL状态的shell脚本

power by soyo123 2007-2008