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;