概述
有时我们要对系统做压测,或者数据库压力测试,这时候需要对某些表插入几百万或者上千万数据,下面介绍下怎么利用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函数生成随机数:
3、随机生成给定数目的字符串
这里用mysql循环,循环采用WHILE循环,循环里面采用字符串拼接函数CONCAT
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 i = i + 1;
END WHILE;
RETURN return_str;
END;复制
用户名和密码都可以通过以上的方式添加
邮箱的添加方式:可直接在insert的value对应字段写上concat(rand_string(5), '@qq.com')
4、随机生成DATE和DATETIME类型
4.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;复制
关于LPAD函数,具体做为月份和日期的补零作用!生效如下介绍
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'复制
4.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 num = num + 1;
END WHILE;
commit;
END;
//复制
调用存储过程:
CALL insertUser;复制
觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~
文章转载自IT实战联盟,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
2982次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
852次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
496次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
436次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
373次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
292次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
280次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
274次阅读
2025-05-06 14:40:00
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
258次阅读
2025-04-30 12:17:54
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
252次阅读
2025-04-28 11:01:25