这期内容当中小编将会给大家带来有关Mysql中怎么按表创建千万级的压测数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1. 准备测试表CREATE TABLE
这期内容当中小编将会给大家带来有关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函数生成随机数:
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;
<img alt="详解Mysql如何按表创建<span><span><span><i @qq.com')
4. 随机生成DATE和DATETIME类型
(1) DATE类型
CREATE DEFINER = `root` @`%` FUNCTION `randDate` ( ) RETURNS VARCHAR ( 255 ) CHARSET utf8 BEGIN DECLARE aDate CHAR ( 10 ) DEFAULT ''; SET aDate = CONCAT( 1949 + FLOOR( ( RAND( ) * 70 ) ), '-', LPAD( FLOOR( 1 + ( RAND( ) * 12 ) ), 2, 0 ), '-', LPAD( FLOOR( 3 + ( RAND( ) * 8 ) ), 2, 0 ) ); RETURN aDate; END;
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;
上述就是小编为大家分享的MySQL中怎么按表创建千万级的压测数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网数据库频道。
--结束END--
本文标题: MySQL中怎么按表创建千万级的压测数据
本文链接: https://lsjlt.com/news/58845.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0