mysql如何进行压测_详解MySQL如何按表创建千万级的压测数据
有時我們要對系統做壓測,或者數據庫壓力測試,這時候需要對某些表插入幾百萬或者上千萬數據,下面介紹下怎么利用MySQL循環和存儲過程對特定表的創建千萬行數據。
1. 準備測試表
CREATE TABLE `username` (
`uid` INT( 11 ) UNSIGNED NOT NULL default 1235678901,
`username` VARCHAR( 20 ) ,
`email` VARCHAR( 30 ) ,
`password` VARCHAR( 32 ) ,
`birthday` date,
`gender` VARCHAR(10) ,
avatar MEDIUMBLOB,
PRIMARY KEY ( `uid` )
) ENGINE = INNODB DEFAULT CHARSET=utf8;
2. 隨機生成數據
MySQL里面自帶一個隨機數生成的函數RAND(),它能生成0-1的浮點數
RAND函數生成隨機數:
詳解MySQL如何按表創建
SET GLOBAL log_bin_trust_function_creators = 1;
CREATE DEFINER = `root` @`%` FUNCTION `rand_string` ( n INT ) RETURNS VARCHAR ( 255 ) CHARSET utf8 BEGIN
DECLARE
chars_str VARCHAR ( 100 ) DEFAULT 'hwbtestABCDEFG23141HIJ6712dfghjkqwevbnqmwerqwerqwreqw214123e1214c12dssaf89';
DECLARE
return_str VARCHAR ( 255 ) DEFAULT '';
DECLARE
i INT DEFAULT 0;
WHILE
i < n DO
SET return_str = concat( return_str, substring( chars_str, FLOOR( 1 + RAND( ) * 80 ), 1 ) );
SET ii = i + 1;
END WHILE;
RETURN return_str;
END;
詳解MySQL如何按表創建
4. 隨機生成DATE和DATETIME類型
(1) DATE類型
CREATE DEFINER = `root` @`%` FUNCTION `randDate` ( ) RETURNS VARCHAR ( 255 ) CHARSET utf8 BEGIN
DECLARE
aDate CHAR ( 10 ) DEFAULT '';
/*CONCAT (1949 + FLOOR( ( RAND( ) * 70 ) ) 表示 1949到2019的隨機數據
--L PAD ( FLOOR( 1 + ( RAND( ) * 12 ) ), 2, 0 ) 表示月份的生成,小于 10自動補0
--L PAD ( FLOOR( 3 + ( RAND( ) * 8 ) ), 2, 0 ) ) 表示 3號到10號的隨機數據 */
SET aDate = CONCAT(
1949 + FLOOR( ( RAND( ) * 70 ) ),
'-',
LPAD( FLOOR( 1 + ( RAND( ) * 12 ) ), 2, 0 ),
'-',
LPAD( FLOOR( 3 + ( RAND( ) * 8 ) ), 2, 0 )
);
RETURN aDate;
END;
詳解MySQL如何按表創建
Returns the string str:str, left-padded with the string padstr to a length of len characters.
If str is longer than len:N, the return value is shortened to len characters.
mysql> SELECT LPAD('hi',4,'??');
-> '??hi'
mysql> SELECT LPAD('hi',1,'??');
-> 'h'
(2) DATETIME類型
在剛剛寫好的randDate上進行改造:
CREATE DEFINER = `root` @`%` FUNCTION `randDateTime` ( ) RETURNS VARCHAR ( 255 ) CHARSET utf8 BEGIN
DECLARE
aDateTime CHAR ( 19 ) DEFAULT '';
SET aDateTime = CONCAT(
CONCAT(
1949 + FLOOR( ( RAND( ) * 70 ) ),
'-',
LPAD( FLOOR( 1 + ( RAND( ) * 12 ) ), 2, 0 ),
'-',
LPAD( FLOOR( 3 + ( RAND( ) * 8 ) ), 2, 0 )
),
' ',
CONCAT(
LPAD( FLOOR( 0 + ( RAND( ) * 23 ) ), 2, 0 ),
':',
LPAD( FLOOR( 0 + ( RAND( ) * 60 ) ), 2, 0 ),
':',
LPAD( FLOOR( 0 + ( RAND( ) * 60 ) ), 2, 0 )
)
);
RETURN aDateTime;
END;
5. 將數據循環插入
定義將數據循環的存儲過程:
DELIMITER //
CREATE PROCEDURE insertUser ( )
BEGIN
DECLARE
num INT;
SET num = 1;
WHILE
num < 100000 DO
INSERT INTO username ( uid,username, email, PASSWORD, birthday, gender, avatar )
VALUES
( num,
rand_string ( 15 ),
concat( rand_string ( 5 ), '@qq.com' ),
rand_string ( 32 ),
randDate ( ),
'男',
NULL
);
SET numnum = num + 1;
END WHILE;
commit;
END;
//
調用存儲過程:
CALL insertUser;
本文內容不用于商業目的,如涉及知識產權問題,請權利人聯系博為峰小編(021-64471599-8017),我們將立即處理
總結
以上是生活随笔為你收集整理的mysql如何进行压测_详解MySQL如何按表创建千万级的压测数据的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql 存储过程 无限分类_mysq
- 下一篇: toad mysql导入excel_Or