一、怎么创建测试数据
如果你会编程语言,那么你可以使用java、python、php等等语言通过对应的工具包操作数据库来完成测试数据的构建。
如果你不会这些语言,恰好你又会一些sql语句,使用存储过程完成测试数据构造是再好不过了。
并且存储过程就是sql脚本,存储、执行、查看结果都在一个工具类就可完成非常方便。(本例采用mysql数据库)
二、什么是存储过程
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,它存储在数据库中, 一次编译后永久有效,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
存储过程是数据库中的一个重要对象。
简单理解:完成特定功能的方法
三、表结构
首先我们先来查看下需要插入测试数据的表member,表中存放的是用户信息。

四、mysql内置函数
通过上图我们已经知道了member表结构,其中RegName用户名一般会不允许重复。
我们需要使用一些随机的或者有规律的字符串。
还有手机号码和注册时间这些都不是固定值,所以需要借助mysql中的内置函数:
CONCAT(str1,str2,...) 拼接多个字符串

MD5(str) md5加密

RAND() 生成一个0-1之间的随机数

NOW()获取当前时间
五、编写存储过程
首先我们先把对member的插入语句写好,之后写存储过程就在这个基础上进行修改

结果:

OK,现在已经成功插入一条数据,接下来我们通过存储过程完成10000条数据的插入。

最后执行存储过程
call CrateTestData();
结果如下

【编辑推荐】
- 记一次生产数据库sql优化案例--23秒优化到0.9秒
- 频繁插入(insert)的业务,用什么存储引擎更合适? | 数据库系列
- 干货!MySQL DAL中间件总结
- MySQL数据库监控指标之吞吐量
- 关于MySQL数据库监控指标总结:缓冲池使用情况
【责任编辑:华轩 TEL:(010)68476606】
点赞 0