在mysql docker容器中执行外部sql脚本

近期项目中,随着需求的迭代需要更新现场生产环境的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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值