成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

MySql中showprofile的用法

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

創(chuàng)新互聯(lián)專注于賓縣企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站開發(fā),商城網(wǎng)站建設(shè)。賓縣網(wǎng)站建設(shè)公司,為賓縣等地區(qū)提供建站服務(wù)。全流程按需定制開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)

以下操作都是session級別的

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

 MySql中show profile的用法

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

MySql中show profile的用法

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

MySql中show profile的用法

通過profile我們能夠更清楚sql執(zhí)行的過程
 

創(chuàng)建一張表插入100萬條數(shù)據(jù):

建表的時(shí)候用MYISAM引擎不需要用事物插入數(shù)據(jù)速度快

 

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 存儲隨機(jī)數(shù)據(jù)*/

)ENGINE=MYISAM DEFAULT CHARSET=utf8;

 

創(chuàng)建存儲過程

 

DELIMITER $$

DROP PROCEDURE IF EXISTS `insert_data`$$

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

BEGIN

  DECLARE n INT DEFAULT 1;/*定義一個變量,存儲當(dāng)前執(zhí)行的次數(shù)*/

       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 $$

 

調(diào)用存儲過程插入100萬條數(shù)據(jù)

 

CALL insert_data('index_test',1000000);

 

將存儲引擎修改為InnoDB

 

ALTER TABLE `index_test` ENGINE=INNODB;

 

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

MySql中show profile的用法

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

MySql中show profile的用法

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

MySql中show profile的用法

Cpu_user:當(dāng)前用戶占有的cpu
Cpu_system系統(tǒng)占有的cpu

本文標(biāo)題:MySql中showprofile的用法
文章位置:http://jinyejixie.com/article22/jjhpcc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、ChatGPT移動網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
塔河县| 斗六市| 滦南县| 会昌县| 榆中县| 济阳县| 大竹县| 江城| 抚顺县| 芜湖市| 诸暨市| 浮梁县| 威信县| 台江县| 阆中市| 宝鸡市| 璧山县| 获嘉县| 柳河县| 故城县| 云阳县| 永康市| 鄂尔多斯市| 集贤县| 渭源县| 仙游县| 巴彦淖尔市| 榆林市| 牙克石市| 钦州市| 麟游县| 稷山县| 阜阳市| 玉溪市| 龙陵县| 阿克苏市| 台安县| 鱼台县| 富源县| 博白县| 江西省|