阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL自动生成大量数据

253次阅读
没有评论

共计 1987 个字符,预计需要花费 5 分钟才能阅读完成。

MySQL 自动生成大量数据

为了学习验证高性能 MySQL,自动生成大量的数据做测试。内容来源于网络。

创建随机数字生成
DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `random_num`() RETURNS int(5)
BEGIN 
 DECLARE i INT DEFAULT 0; 
 SET i = FLOOR(100+RAND()*10); 
RETURN i; 
 END$$
DELIMITER ;

生成随机字符串
DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `random_string`(n INT) RETURNS varchar(255) CHARSET latin1
BEGIN
 DECLARE chars_str VARCHAR(100) DEFAULT ‘abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ’;
 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()*52),1));
 SET i = i + 1;
 END WHILE;
 RETURN return_str;
END$$
DELIMITER ;

生成随机数字,返回 varchar 类型数据组合,例如手机号
DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `random_string_phone`(n INT) RETURNS varchar(255) CHARSET latin1
BEGIN
 DECLARE chars_str VARCHAR(100) DEFAULT ‘1234567890’;
 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()*10),1));
 SET i = i + 1;
 END WHILE;
 RETURN return_str;
END$$
DELIMITER ;

创建用户表 myisam 引擎
CREATE TABLE `sys_user_myisam` (
  `user_id` bigint(100) NOT NULL AUTO_INCREMENT,
  `username` varchar(100) DEFAULT NULL COMMENT ‘ 用户名 ’,
  `password` varchar(100) DEFAULT NULL COMMENT ‘ 密码 ’,
  `salt` varchar(100) DEFAULT NULL COMMENT ‘ 盐 ’,
  `email` varchar(100) DEFAULT NULL COMMENT ‘ 邮箱 ’,
  `mobile` varchar(100) DEFAULT NULL COMMENT ‘ 手机号 ’,
  `status` int(1) DEFAULT ‘1’ COMMENT ‘ 状态  0:禁用  1:正常 ’,
  PRIMARY KEY (`user_id`)
) ENGINE=MyISAM AUTO_INCREMENT=1000001 DEFAULT CHARSET=utf8 COMMENT=’ 系统用户 MyISAM’;

创建存储过程生成数据
DELIMITER $$
CREATE DEFINER=`root`@`%` PROCEDURE `insert_sys_user_myisam`(IN START INT(10),IN max_num INT(10))
BEGIN 
DECLARE i INT DEFAULT 0; 
 SET autocommit = 0;   
 REPEAT 
 SET i = i + 1; 
 INSERT INTO sys_user_myisam (user_id,username,password,salt,email,mobile,status) VALUES (START+i,random_string(10),random_string(6),random_string(10),random_string(20),random_string_phone(12),1); 
 UNTIL i = max_num 
 END REPEAT; 
 COMMIT; 
 END$$
DELIMITER ;

创建表 innodb 引擎
create table sys_user_innodb ENGINE=MyISAM AUTO_INCREMENT=1000001 DEFAULT CHARSET=utf8 as select * from sys_user_myisam;

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1987字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中