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=INNODBDEFAULTCHARSET=utf8;

2. 随机生成数据

MySQL里面自带一个随机数生成的函数RAND(),它能生成0-1的浮点数

RAND函数生成随机数:

606194.htm

SET GLOBALlog_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

SET return_str=concat( return_str, substring( chars_str, FLOOR( 1 + RAND( ) * 80 ), 1 ) );

SET ii= i + 1;

END WHILE;

RETURN return_str;

END;

606194.htm

CREATEDEFINER= `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;

606194.htm

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上进行改造:

CREATEDEFINER= `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 <100000DO

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;

【编辑推荐】

【责任编辑:赵宁宁 TEL:(010)68476606】

点赞 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值