• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql中查询联接工作状态_mysql

mysql 搞代码 7年前 (2018-06-08) 175次浏览 已收录 0个评论

mysql中查询连接工作状态
#!/bin/bash
while true
do
mysql -uroot -e ‘show processlist/G’|grep State:|uniq -c|sort -rn
echo ‘—‘
sleep 1
Done

如果观察到以下状态,则需要注意
converting HEAP to MyISAM 查询结果太大时,把结果放在磁盘 (语句写的不好,取数据太多)
create tmp table             创建临时表(如group时储存中间结果,说明索引建的不好)
Copying to tmp table on disk   把内存临时表复制到磁盘 (索引不好,表字段选的不好)
locked         被其他查询锁住 (一般在使用事务时易发生,互联网应用不常发生)
logging slow query 记录慢查询
mysql 5.5 以后加了一个profile设置,可以观察到具体语句的执行步骤.
0:查看profile是否开启

> Show  variables like ‘profiling’
+—————+——-+
| Variable_name | Value |
+—————+——-+
| profiling     | OFF   |
+—————+——-+

1:> set profiling=on;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| profiling     | On      |
+—————+——-+

mysql> show profiles;
+———-+————+———————————————————-+
| Query_ID | Duration   | Query                                                    |
+———-+————+———————————————————-+
|        1 | 0.00034225 | select cat_id,avg(shop_price) from goods group by cat_id |
+———-+————+———————————————————-+
1 row in set (0.00 sec)

mysql> show profile for query 1;
+———————-+———-+
| Status               | Duration |
+———————-+———-+
| starting             | 0.000058 |
| checking permissions | 0.000008 |


| Sorting result       | 0.000004 |
| Sending data         | 0.000120 |
| end                  | 0.000005 |
| query end            | 0.000006 |
| closing tables       | 0.000008 |
| freeing items        | 0.000023 |
| logging slow query   | 0.000003 |
| cleaning up          | 0.000004 |
+———————-+———-+

欢迎大家阅读《mysql中查询联接工作状态_mysql》,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql中查询联接工作状态_mysql
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址