随机生成万分测试数据

-- 创建一个临时内存表
DROP TABLE IF EXISTS `vote_record_memory`;
CREATE TABLE `vote_record_memory` (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
    `user_id` varchar(20) NOT NULL DEFAULT '',
    `vote_num` int(10) unsigned NOT NULL DEFAULT '0',
    `group_id` int(10) unsigned NOT NULL DEFAULT '0',
    `status` tinyint(2) unsigned NOT NULL DEFAULT '1',
    `create_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
    PRIMARY KEY (`id`),
    KEY `index_user_id` (`user_id`) USING HASH
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
DROP TABLE IF EXISTS `vote_record`;
CREATE TABLE `vote_record` (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
    `user_id` varchar(20) NOT NULL DEFAULT '' COMMENT '用户Id',
    `vote_num` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '投票数',
    `group_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户组id 0-未激活用户 1-普通用户 2-vip用户 3-管理员用户',
    `status` tinyint(2) unsigned NOT NULL DEFAULT '1' COMMENT '状态 1-正常 2-已删除',
    `create_time` datetime unsigned NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',
    PRIMARY KEY (`id`),
    KEY `index_user_id` (`user_id`) USING HASH COMMENT '用户ID哈希索引'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='投票记录表';

DROP TABLE IF EXISTS `vote_record_memory`;
CREATE TABLE `vote_record_memory` (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
    `user_id` varchar(20) NOT NULL DEFAULT '',
    `vote_num` int(10) unsigned NOT NULL DEFAULT '0',
    `group_id` int(10) unsigned NOT NULL DEFAULT '0',
    `status` tinyint(2) unsigned NOT NULL DEFAULT '1',
    `create_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
    PRIMARY KEY (`id`),
    KEY `index_user_id` (`user_id`) USING HASH
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;


DROP TABLE IF EXISTS `vote_record`;
CREATE TABLE `vote_record` (
    `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
    `user_id` varchar(20) NOT NULL DEFAULT '' COMMENT '用户Id',
    `vote_num` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '投票数',
    `group_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户组id 0-未激活用户 1-普通用户 2-vip用户 3-管理员用户',
    `status` tinyint(2) unsigned NOT NULL DEFAULT '1' COMMENT '状态 1-正常 2-已删除',
    `create_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',
    PRIMARY KEY (`id`),
    KEY `index_user_id` (`user_id`) USING HASH
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='投票记录表';


-- 创建生成长度为n的随机字符串的函数
DELIMITER // -- 修改MySQL delimiter:'//'
DROP FUNCTION IF EXISTS `rand_string` //
SET NAMES utf8 //
CREATE FUNCTION `rand_string` (n INT) RETURNS VARCHAR(255) CHARSET 'utf8'
BEGIN 
    DECLARE char_str varchar(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
    DECLARE return_str varchar(255) DEFAULT '';
    DECLARE i INT DEFAULT 0;
    WHILE i < n DO
        SET return_str = concat(return_str, substring(char_str, FLOOR(1 + RAND()*62), 1));
        SET i = i+1;
    END WHILE;
    RETURN return_str;
END //


-- 创建插入数据的存储过程
DROP PROCEDURE IF EXISTS `add_vote_record_memory` //
CREATE PROCEDURE `add_vote_record_memory`(IN n INT)
BEGIN
    DECLARE i INT DEFAULT 1;
    DECLARE vote_num INT DEFAULT 0;
    DECLARE group_id INT DEFAULT 0;
    DECLARE status TINYINT DEFAULT 1;
    WHILE i < n DO
        SET vote_num = FLOOR(1 + RAND() * 10000);
        SET group_id = FLOOR(0 + RAND()*3);
        SET status = FLOOR(1 + RAND()*2);
        INSERT INTO `vote_record_memory` VALUES (NULL, rand_string(5), vote_num, group_id, status, NOW());
        SET i = i + 1;
    END WHILE;
END //
DELIMITER ;  -- 改回默认的 MySQL delimiter:';'


-- 调用存储过程 生成100W条数据
CALL add_vote_record_memory(1000000);


SELECT count(*) FROM `vote_record_memory`;
-- count(*)
-- 105646


INSERT INTO vote_record SELECT * FROM `vote_record_memory`;


SELECT count(*) FROM `vote_record`;
-- count(*)
-- 105646


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
wings是一款用于单元测试测试用例驱动框架自动生成工具,这款工具主要是全自动生成单元测试驱动代码与测试数据。解决做单元测试耗时耗力,编写难度大等问题。提升开发和测试效率。 特点: (1) 程序参数深度分析问题 Wings通过编译器底层技术,将输入的源文件,按照函数为单位,形成模块对象。对象中包含函数的输入参数,返回值类型等信息,供驱动函数模块和测试用例模块使用。每个文件作为一个单元,针对其中的每个函数的每个参数进行深度解析,对于嵌套类型,复杂类型等都可以实现精确的解析和分解,将复杂类型逐层讲解为基础数据类型,并产生参数结构的描述文件(PSD)。 (2) 函数驱动自动生成模块 依据PSD文件的格式信息,自动生成被测源程序的所有驱动函数,单元测试过程不再依赖开发人员手动编写测试函数,只需将生成的驱动函数和被测源文件一起编译,即可执行测试并查看测试结果。测试驱动自动生成程序基于PSD描述,全自动构建驱动被测程序运行的所有参数,必须的全局变量,并可根据复杂变量的层级结构产生结构化的测试驱动程序,可以节省大量的单元测试用例的编写时间。 (3) 测试数据自动生成与管理 用于自动生成测试数据测试数据与被测函数提取的信息相互对应,数据以一定的层次逻辑关系存储在json文件中。数据和经过分解和展开后的数据类型是一一对应的。这些数据用户可以根据业务要求随意边际,并且用json文件进行结构化,层次化展示,非常的清晰。其中的测试数据包括全局变量值、被测函数调用时的参数值。 优点: 1. 可以为任意复杂参数结构C语言开发的系统全自动生成测试驱动程序 2. 可完成对于被测试函数的参数进行多层编译解析,并完成复杂参数赋值的代码的自动生成。 3. 支持被测函数引用的全局变量的分析和自动赋值程序的生成。 4. 能够区分系统变量和用户变量,对于复杂的系统变量可由用户自定义赋值模板。 例如File类型,而不是把复杂的系统变量全部展开。 5. 支持多层次的可视化的数据表格来对变量进行赋值,而无需关注驱动程序本身。 数据表格可以表达任意深度和多层次的数据关系,用户只需要对表格数据进行编辑,自动生成的驱动程序会自动完成表格数据的读取和参数赋值的构造过程。 6. Wings支持所有C语言的数据类型(基础类型,结构体,指针,数组,枚举等)以及高层级数据结构。 例如链表的分析和对应的驱动和数据表格框架的生成。 7. Wings生成的代码与人工写的非常相近,可读性强,自带注释和按照层次的缩进和代·码编排。
### 回答1: 生成 MySQL 测试数据的工具是一种能够帮助开发者生成大量数据并快速向数据库中插入数据的工具。这种工具可以帮助开发者加快开发进程,减小因为数据不足而造成的测试问题。以下是一些常见的生成 MySQL 测试数据的工具: 1. Mockaroo:Mockaroo 是一个在线的数据生成器,可以生成多种格式的数据,并通过 API 或 CSV 导出数据。开发者可以根据需要轻松设定数据类型并生成大量的假数据。 2. DataFactory:DataFactory 是一款流行的免费数据生成器,可以生成 SQL、CSV 和 XML 格式的数据。它支持均匀或随机生成数据、舍入、分布等多种选项,并可以通过 Web UI 或 REST API 使用。 3. dbForge Data Generator for MySQL:dbForge Data Generator for MySQL 是一款强大的工具,专门用于生成大量数据用于测试。它提供了许多配置选项,包括数据类型、约束、表关系和自定义函数。 4. SQL Data Generator:SQL Data Generator 是一款面向 MySQL 和其他流行数据库的数据生成器。它提供了多种数据类型、数据生成方法和数据集选项,并可以轻松生成数百万条数据。 这些生成 MySQL 测试数据的工具,可以帮助开发者更好的测试数据库架构,并能够加快开发周期,提高开发效率。开发者可以根据需求选择不同的工具,以便满足测试需求。 ### 回答2: MySQL是一种常用的数据库,它的测试数据对于软件开发过程中的测试非常重要。为了生成MySQL测试数据,我们可以使用一些工具。 首先,MySQL自带了一些生成测试数据的函数,例如RAND()和UUID()等。这些函数可以生成随机的数字和唯一的标识符,用于测试数据的填充和建表。 其次,还有一些第三方工具可用于生成MySQL测试数据,例如DataFiller、dbForge Data Generator和dbForge Studio等,这些工具具有可视化的用户界面和丰富的选项。使用这些工具可以生成指定数量、范围和规则的测试数据,并且可以自动填充整个数据库中的数据。 最后,我们还可以编写脚本和程序来生成MySQL测试数据。例如,我们可以使用Python和SQLAlchemy编写脚本来生成测试数据,或者使用Java和JDBC编写程序来批量插入数据。这些方法需要一定的编程知识和技能,但是可以灵活地生成各种类型的测试数据。 总之,生成MySQL测试数据的工具有很多种,我们可以根据实际需求选取最合适的工具来进行数据生成。在软件开发过程中,测试数据的质量和数量往往直接影响到软件质量和稳定性,因此生成好的测试数据对于保证软件的质量和稳定性是非常重要的。 ### 回答3: 生成MySQL测试数据的工具有很多,其中比较常用的有以下几种: 1. 数据库自带工具:MySQL提供了很多工具来生成测试数据,如mysqldump、mysqlslap、mysqladmin等。其中mysqldump是备份和恢复MySQL数据库中常用的命令,也可以利用其生成测试数据。 2. 第三方开源工具:比较流行的有faker、dbForge Data Generator、DataFly、Test Data Generator等。这些工具可以根据用户需求自动生成各种测试数据,如随机生成姓名、性别、邮箱、地址等。 3. 编程语言自带库:比如Python的faker库、Java的随机数类等,可以方便地生成各种测试数据,且可以在程序中方便地使用。 无论采用哪种工具,生成MySQL测试数据的目的都是为了保证系统在真实数据环境下的正常运行。因此,在使用这些工具的时候,需要注意生成数据的规模、数据类型的正确性以及数据的有效性等问题,以便为系统性能测试或数据分析提供准确的基础数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值