要执行 db/migrations/ 目录下的多个 SQL 文件以迁移数据库,可以按照以下步骤进行:
1 确认 PostgreSQL 容器正在运行:
确认你已经启动了 PostgreSQL 容器并且它在运行:
docker ps -a
2 确认容器 beaconchain 是 Up 状态。
将 SQL 文件复制到容器中:
如果你的 SQL 文件在宿主机上的 db/migrations/ 目录下,你需要将这些文件复制到 Docker 容器中。假设你当前目录是包含 db/migrations/ 的目录:
docker cp db/migrations/. beaconchain:/migrations
3 在容器中执行 SQL 文件:
进入容器并执行这些 SQL 文件。你可以使用以下脚本依次执行 migrations 目录下的所有 SQL 文件:
docker exec -it beaconchain bash
进入容器后,可以使用如下脚本执行所有 SQL 文件:
for file in /migrations/*.sql; dopsql -U beaconchain -d beaconchain -f "$file"
done
4 在宿主机上直接执行 SQL 文件:
如果你不想进入容器,也可以从宿主机直接执行这些 SQL 文件。确保你当前目录是包含 db/migrations/ 的目录:
for file in db/migrations/*.sql; dodocker exec -i beaconchain psql -U beaconchain -d beaconchain -f "$file"
done
这段脚本会循环遍历 db/migrations/ 目录下的所有 .sql 文件,并通过 docker exec 命令在容器中执行每个 SQL 文件。
总结一下:
确认 PostgreSQL 容器正在运行。
将 SQL 文件复制到容器中。
在容器内或从宿主机上依次执行每个 SQL 文件。
如果执行过程中遇到错误,请提供具体的错误信息以便进一步诊断和解决。