zoukankan      html  css  js  c++  java
  • 如何快速创建百万级测试数据

    场景

    进行SQL优化或查询性能测试时,我们需要大量数据测试来模拟,这个时候引出一个问题:数据的创建

    如何快速创建大量数据

    创建数据无非几种操作下面一一列举;
    1 手动输入 (可忽略)
    2 使用编写好的存储过程和函数执行 (下面会有介绍)
    3 编写代码,通过代码插入数据 (例:使用mybatis的foreach循环插入..步骤多,速度慢)
    4 临时数据表方式执行 (强烈推荐,速度快,简单)

    准备操作前提

    首先 我们不管选哪种操作 都要先准备一张表,这个是毫无疑问的;
    那么我们就简单的创建一个表 如下;

    CREATE TABLE `t_user` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `c_user_id` varchar(36) NOT NULL DEFAULT '',
      `c_name` varchar(22) NOT NULL DEFAULT '',
      `c_province_id` int(11) NOT NULL,
      `c_city_id` int(11) NOT NULL,
      `create_time` datetime NOT NULL,
      PRIMARY KEY (`id`),
      KEY `idx_user_id` (`c_user_id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
    

    使用存储过程和内存表

    我们先利用函数和存储过程在内存表中生成数据,再从内存表中插入普通表

    1 创建一个内存表

    CREATE TABLE `t_user_memory` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `c_user_id` varchar(36) NOT NULL DEFAULT '',
      `c_name` varchar(22) NOT NULL DEFAULT '',
      `c_province_id` int(11) NOT NULL,
      `c_city_id` int(11) NOT NULL,
      `create_time` datetime NOT NULL,
      PRIMARY KEY (`id`),
      KEY `idx_user_id` (`c_user_id`)
    ) ENGINE=MEMORY DEFAULT CHARSET=utf8mb4;
    

    2 创建函数和存储过程

    # 创建随机字符串和随机时间的函数
    mysql> delimiter $$
    mysql> CREATE DEFINER=`root`@`%` FUNCTION `randStr`(n INT) RETURNS varchar(255) CHARSET utf8mb4
        ->     DETERMINISTIC
        -> BEGIN
        ->     DECLARE chars_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(chars_str, FLOOR(1 + RAND() * 62), 1));
        ->         SET i = i + 1;
        ->     END WHILE;
        ->     RETURN return_str;
        -> END$$
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> CREATE DEFINER=`root`@`%` FUNCTION `randDataTime`(sd DATETIME,ed DATETIME) RETURNS datetime
        ->     DETERMINISTIC
        -> BEGIN
        ->     DECLARE sub INT DEFAULT 0;
        ->     DECLARE ret DATETIME;
        ->     SET sub = ABS(UNIX_TIMESTAMP(ed)-UNIX_TIMESTAMP(sd));
        ->     SET ret = DATE_ADD(sd,INTERVAL FLOOR(1+RAND()*(sub-1)) SECOND);
        ->     RETURN ret;
        -> END $$
    
    mysql> delimiter ;
    
    # 创建插入数据存储过程
    mysql> CREATE DEFINER=`root`@`%` PROCEDURE `add_t_user_memory`(IN n int)
        -> BEGIN
        ->     DECLARE i INT DEFAULT 1;
        ->     WHILE (i <= n) DO
        ->         INSERT INTO t_user_memory (c_user_id, c_name, c_province_id,c_city_id, create_time) VALUES (uuid(), randStr(20), FLOOR(RAND() * 1000), FLOOR(RAND() * 100), NOW());
        ->         SET i = i + 1;
        ->     END WHILE;
        -> END
        -> $$
    Query OK, 0 rows affected (0.01 sec)
    

    调用存储过程

    mysql> CALL add_t_user_memory(1000000);   //添加的数据量
    ERROR 1114 (HY000): The table 't_user_memory' is full
    

    PS:出现ERROR 1114 (HY000): The table 't_user_memory' is full错误,表示内存已满

    处理方式:修改 max_heap_table_size 参数的大小 默认32M或者64M就好,生产环境不要乱尝试哦.

    从内存表插入普通表

    mysql> INSERT INTO t_user SELECT * FROM t_user_memory;
    Query OK, 218953 rows affected (1.70 sec)
    Records: 218953  Duplicates: 0  Warnings: 0
    

    临时表方式

    创建临时数据表tmp_table

    CREATE TABLE tmp_table (
        id INT,
        PRIMARY KEY (id)
    );
    

    python:
    python -c "for i in range(1, 1+1000000): print(i)" > base.txt

    导入数据到临时表tmp_table中

    load data infile '/Users/LJTjintao/temp/base.txt' replace into table tmp_table;
    Query OK, 1000000 rows affected (2.55 sec)
    Records: 1000000 Deleted: 0 Skipped: 0 Warnings: 0

    关注公众号:java宝典
    a

  • 相关阅读:
    systemtap分析软raid io拆分问题
    Profiling Java Application with Systemtap
    中国南方ORACLE用户组
    Docker 核心技术与实现原理
    The Internals of PostgreSQL
    Alone_Monkey 逆向IOS
    淘宝内核月报 2017
    Linux kernel engineer--trace
    你的按钮到底在帮助用户还是在误导用户?
    2020年值得你去试试的10个React开发工具
  • 原文地址:https://www.cnblogs.com/java-bible/p/13856151.html
Copyright © 2011-2022 走看看