docker创建postgreSql带多个init的sql
好的!下面是一个完整的可运行项目结构,包含:
-
✅
docker-compose.yml
:启动 PostgreSQL(支持 pgvector) -
✅
init-db.sql
:创建数据库myapp
-
✅
init-schema.sql
:在myapp
中建表并初始化数据 -
✅ 自动执行顺序正确,无需手动干预
🗂 项目结构
your-project/
├── docker-compose.yml
├── init-db.sql
├── init-schema.sql
└── data/ <-- 容器初始化后生成(不要提前创建)
📄 1. docker-compose.yml
version: "3.8"services:postgres:image: pgvector/pgvector:pg16container_name: my-postgresenvironment:POSTGRES_PASSWORD: rootports:- "5432:5432"volumes:- ./data:/var/lib/postgresql/data- ./init-db.sql:/docker-entrypoint-initdb.d/01-init-db.sql- ./init-schema.sql:/docker-entrypoint-initdb.d/02-init-schema.sqlrestart: always
📄 2. init-db.sql
-- 创建数据库 myapp CREATE DATABASE myapp;
📄 3. init-schema.sql
-- 切换到 myapp 数据库
\connect myapp-- 创建用户表
CREATE TABLE users (id SERIAL PRIMARY KEY,name TEXT NOT NULL,email TEXT UNIQUE NOT NULL,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);-- 插入测试数据
INSERT INTO users (name, email) VALUES
('Alice', 'alice@example.com'),
('Bob', 'bob@example.com');
✅ 启动项目
确保当前目录下没有已有 data/
文件夹(PostgreSQL 启动时需要创建空数据库)
docker-compose down -v # 清除旧容器和卷(第一次运行推荐)
rm -rf ./data # 删除旧数据目录,确保执行初始化脚本
docker-compose up -d # 启动容器
🔎 验证
登录数据库检查数据是否已插入:docker exec -it my-postgres psql -U postgres -d myapp然后执行:\d -- 查看表 SELECT * FROM users;