91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySql中show profile的用法

發布時間:2020-05-29 14:41:54 來源:億速云 閱讀:394 作者:鴿子 欄目:編程語言

Mysql從5.0.3版本開始增加了對show profiles和show profile的支持,show profile能夠幫我們了解在sql語句執行過程中時間耗費在了哪些地方

以下操作都是session級別的

我們可以通過 select @@have_profiling來顯示當前mysql是否支持profile:

 MySql中show profile的用法

通過 select @@profiling查看profile是否開啟

MySql中show profile的用法

如果為0未開啟通過 set profiling =1 開啟

MySql中show profile的用法

通過profile我們能夠更清楚sql執行的過程
 

創建一張表插入100萬條數據:

建表的時候用MYISAM引擎不需要用事物插入數據速度快

 

DROP TABLE IF EXISTS index_test;

CREATE TABLE index_test(

id BIGINT(20) PRIMARY KEY NOT NULL AUTO_INCREMENT,

USER VARCHAR(16) DEFAULT NULL,

psd VARCHAR(64) DEFAULT NULL

/*psd mediumint DEFAULT 0 存儲隨機數據*/

)ENGINE=MYISAM DEFAULT CHARSET=utf8;

 

創建存儲過程

 

DELIMITER $$

DROP PROCEDURE IF EXISTS `insert_data`$$

CREATE PROCEDURE `insert_data`(IN tableName VARCHAR(500),IN num INT)

BEGIN

  DECLARE n INT DEFAULT 1;/*定義一個變量,存儲當前執行的次數*/

       WHILE n <= num DO

              SET @sqlStr = CONCAT("INSERT INTO ",tableName,"(USER,psd) VALUES(CONCAT(",n,",'用戶'),password(",n,"))");

              PREPARE stmt FROM @sqlStr;

              EXECUTE stmt;

              SET n=n+1;

  END WHILE;

END $$

 

調用存儲過程插入100萬條數據

 

CALL insert_data('index_test',1000000);

 

將存儲引擎修改為InnoDB

 

ALTER TABLE `index_test` ENGINE=INNODB;

 

 
我們執行一系列的sql語句:
Show databases;
Use test;
Select * from index_test;
Select count(*) from index_test;
然后執行show profiles;

MySql中show profile的用法

可以看到每個sql語句執行的時間
通過 show profile for query query_id可以查看該sql語句執行的過程中線程的狀態和在每個狀態消耗的時間

MySql中show profile的用法

我們可以看到Sending data耗時最長,這個狀態表示mysql線程開始訪問數據行并將數據返回給客戶端,它既包含有訪問數據的操作也包含有返回客戶端的操作。因為在訪問數據的過程中有大量的磁盤操作,所以通常耗時是最長的。
在獲取到最消耗時間的狀態以后還可以進一步查看mysql使用資源所耗費的時間,比如查看cpu耗費的時間可以用 show profile cpu for query 4;

MySql中show profile的用法

Cpu_user:當前用戶占有的cpu
Cpu_system系統占有的cpu


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吴桥县| 都匀市| 上饶县| 宁国市| 烟台市| 井冈山市| 肃宁县| 桓仁| 武宁县| 策勒县| 桃江县| 平湖市| 东兰县| 肇源县| 达州市| 大化| 兴隆县| 铁岭县| 封开县| 合江县| 永嘉县| 获嘉县| 西峡县| 遵义市| 威远县| 长沙县| 和平县| 五河县| 二连浩特市| 道孚县| 武鸣县| 靖宇县| 南皮县| 乳山市| 垣曲县| 托里县| 青岛市| 和静县| 邓州市| 东兰县| 阳原县|