docker+mysql 执行存储过程构造大量测试数据

docker拉取mysql镜像并导入sql文件执行

#拉取镜像
$ docker pull mysql:5.7
#查看镜像
$ docker images
#运行docker  mysql密码123456  宿主机端口号3306 映射 容器端口号3306
$ docker run -itd --name mysql-test -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
#查看进程  可以找到运行的容器id
$ docker ps
#进入容器 exec方式进入容器后通过exit退出容器时,不会关闭容器
$ docker exec -it 95a6dd388742 bash
#退出容器
$ exit
#删除容器  容器id
$ docker rm -f ca1172e3788d
#删除镜像   镜像id
$ docker rmi -f 9b9cb95443b5

#宿主机sql文件复制进docker  [cp 宿主机文件路径 容器id:容器内路径]   容器内路径必须是已存在的路径
$ docker cp /Users/v_weishan/Downloads/mysql.sql 95a6dd388742:/import/

#进入容器后
#进入数据库
$ mysql -h localhost -u root -p123456
#新建数据库
$ create database test;
#进入数据库
$ use test;
#执行导入的sql文件  [source sql文件路径]
$ source /import/mysql.sql

docker安装vim

#同步 /etc/apt/sources.list 和 /etc/apt/sources.list.d 中列出的源的索引,这样才能获取到最新的软件包
$ apt-get update 
#安装
$ apt-get install vim

mysql操作,执行存储过程

// 导入创建语句执行 `create_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '' 时报错 ERROR 1067 (42000): Invalid default value for 'create_time'
//查看数据库配置
SHOW VARIABLES LIKE 'sql_mode%';
+---------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| Variable_name | Value                                                                                                                                     |
+---------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| sql_mode      | ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+---------------+-------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.27 sec)


//NO_ZERO_IN_DATE,NO_ZERO_DATE影响日期默认值
//不重启mysql的情况下设置。临时生效,重新连接mysql后失效
set sql_mode=(select replace(@@sql_mode,'NO_ZERO_IN_DATE,NO_ZERO_DATE',''));


//插入数据
//插入45w条数据,60%的数据固定同一parentid(971728552)
//is_dir为0/1,is_del为0/1,parent_path为<person>parentid:
//存储过程
delimiter $$$
CREATE PROCEDURE add_data()
BEGIN
    declare i int default 0; //插入45w条数据
    declare targetid int default 0; //随机数,60%的数据固定同一parentid
    declare parentid int default 0; 
    
    set i=0;
    while i<450000 DO          
        set targetid = ROUND(RAND() * 100);
        IF targetid<=60 THEN
            set parentid=971728552;
        ELSE
            set parentid= ROUND(RAND() * 100000000);
        END IF;
        insert into doc_file_meta(file_name, is_dir, parent_path, is_del) values('测试文件名称', ROUND(RAND()), concat('<person>',parentid, ':'), ROUND(RAND()));
        set i=i+1;
    END WHILE; 
END $$$
delimiter;
//执行存储过程
call add_data();


//终止执行存储过程
//查看所有mysql线程,找到id
SHOW PROCESSLIST; 
//终止 kill id
KILL 749;

上一篇:树莓派 Zero 与 Zero W 对比


下一篇:「USACO2.3」Zero Sum