您好,登錄后才能下訂單哦!
Mysql從5.0.3版本開始增加了對show profiles和show profile的支持,show profile能夠幫我們了解在sql語句執行過程中時間耗費在了哪些地方
以下操作都是session級別的
我們可以通過 select @@have_profiling來顯示當前mysql是否支持profile:
創建一張表插入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;
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。