近期项目中,随着需求的迭代需要更新现场生产环境的mysql数据库,由于现场支持人员没有Navicat这类的客户端软件,需要通过命令行的方式更新数据库。通过查阅文章,总结有两种更新方式。
方式一: 直接通过docker exec 进行更新
数据库更新
1. 上传sql脚本文件到服务器(本例中为test.sql,其内容如下
).
CREATE TABLE `test_create_table` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'ID',
`create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',
`update_by` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '修改人',
`update_time` datetime(0) NULL DEFAULT NULL COMMENT '修改时间',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 8618912320289 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '告警记录表' ROW_FORMAT = Dynamic;
2. 通过docker container ls
查看待更新的容器名(本例中为mysql-test
).
3. 在容器中执行sql脚本.
docker exec -i mysql-test mysql -uroot -p${YOURPASSWORD} ${YOURDB} < test.sql
验证更新
1. 进入数据库.
docker exec -it mysql-test mysql -uroot -p${YOURPASSWORD} ${YOURDB}
2. 通过mysql指令验证更新.
show tables;
desc test_create_table;
方式二: 直接通过docker cp 及docker exec 拷贝到容器中进行更新
1. 上传sql脚本文件到服务器(本例中为test.sql
).
2. 通过docker container ls
查看待更新的容器名(本例中为mysql-test
).
3. 通过docker cp将sql脚本拷贝到容器
.
docker cp ./test.sql mysql-test:/test.sql
4. 进入容器,在容器本地执行sql文件
docker exec -it mysql-test /bin/bash
bash-4.2# cd /
bash-4.2# mysql -uroot -p${YOURPASSWORD} < test.sql