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;