有时我们要对系统做压测,或者数据库压力测试,这时候需要对某些表插入几百万或者上千万数据,下面介绍下怎么利用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如何按表创建千万级的压测数据相关推荐

  1. mysql影响行数解析_详解MySQL的数据行和行溢出机制

    一.行 有哪些格式? 你可以像下面这样看一下你的mysql行格式设置. 其实mysql的数据行有两种格式,一种就是图中的 compact格式,还有一种是redundant格式. compact是一种紧 ...

  2. mysql如何查看事务日记_详解 Mysql 事务和Mysql 日志

    事务特性 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节. 2.一致性(Consistency):事务开始前和结束后,数据库的完整性约束没有被破 ...

  3. mysql 中default什么意思_详解MySQL中default的使用

    NULL 和 NOT NULL 修饰符.DEFAULT 修饰符,AUTO_INCREMENT 修饰符. NULL 和 NOT NULL 修饰符 可以在每个字段后面都加上这 NULL 或 NOT NUL ...

  4. mysql function函数_详解MySQL如何按表创建千万级的压测数据

    概述 有时我们要对系统做压测,或者数据库压力测试,这时候需要对某些表插入几百万或者上千万数据,下面介绍下怎么利用MySQL循环和存储过程对特定表的创建千万行数据. 1.准备测试表 CREATE TAB ...

  5. mysql datetime 转date_详解MySQL如何按表创建千万级的压测数据

    概述 有时我们要对系统做压测,或者数据库压力测试,这时候需要对某些表插入几百万或者上千万数据,下面介绍下怎么利用MySQL循环和存储过程对特定表的创建千万行数据. 1.准备测试表 CREATE TAB ...

  6. mysql内连接部门平均值_详解MySql基本查询、连接查询、子查询、正则表达查询_MySQL...

    查询数据指从数据库中获取所需要的数据.查询数据是数据库操作中最常用,也是最重要的操作.用户可以根据自己对数据的需求,使用不同的查询方式.通过不同的查询方式,可以获得不同的数据.MySQL中是使用SEL ...

  7. mysql查询男生基本情况_详解MySql基本查询、连接查询、子查询、正则表达查询...

    select * from STUDENT; 2.2.按条件查询 (1) 比较运算符 > , < ,= , != (< >),>= , <= select * fr ...

  8. mysql执行事务的语句_详解MySQL执行事务的语法和流程

    摘要:MySQL 提供了多种存储引擎来支持事务. MySQL 提供了多种存储引擎来支持事务.支持事务的存储引擎有 InnoDB 和 BDB,其中,InnoDB 存储引擎事务主要通过 UNDO 日志和 ...

  9. mysql操作日志记录查询_详解mysql数据库参数log_timestamps--控制日志记录使用的时区...

    概述 最近发现之前安装的MySQL 5.7.27,其中的error log.general log日志里面日志时间的时区不对. 思路: mysql 5.7.2新增了参数 log_timestamps, ...

最新文章

  1. insta经典滤镜下载
  2. 暮色森林模组_我的世界暮色森林mod全攻略,尤其是Boss击杀顺序,一定要牢记...
  3. C++的4种类型转换关键字及其特点
  4. 【渝粤题库】陕西师范大学200341实变函数作业(高起本、专升本)
  5. 前端学习(2917):上午回顾
  6. 二层环路保护,RRPP多环的配置
  7. 动态规划经典题之编辑距离
  8. pcb文件转成原理图_电路仿真与PCB设计 | 文末赠书
  9. DeFi货币市场协议DMM宣布因监管部门的要求,已停止运营
  10. loj 6083.「美团 CodeM 资格赛」数码
  11. 代码行数统计工具,java,go,c++,html文件都适用
  12. 网易云音乐 网络错误 linux,解决ubuntu安装网易云音乐失败的方法
  13. android 坐标度分秒转换工具,android 经纬度度分秒与十进制之间的相互转换
  14. 【CSS】浅谈 CSS 中常用的相对长度单位 em, rem
  15. fid fopen MATLAB
  16. 【知识向】——计算机基础知识总结及相关
  17. PowerPoint2003常用快捷键
  18. qpython oh下载_QPython OH
  19. 欢乐喜剧人之个人见解
  20. Maya offline document

热门文章

  1. NEO改进协议提案2(NEP-2)
  2. 在浏览器中输入网址后的流程
  3. 让互联网拥抱移动VR,三星将发布新版VR浏览器
  4. 常用系统存储过程有:
  5. CruiseControl.NET开篇
  6. CentOS 6.5 LVM磁盘管理学习笔记
  7. f_bfree和f_bavail的区别
  8. Epicor 安装Enterprise search
  9. C++的IO流的函数
  10. Postgres-XL的使用与动态增删数据节点