当前位置: 首页 > article >正文

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;

http://www.lryc.cn/news/2399452.html

相关文章:

  • 掌握 MotionLayout:交互动画开发
  • SpringBoot中缓存@Cacheable出错
  • iOS UIActivityViewController 组头处理
  • 分布式电源接入配电网的自适应电流保护系统设计与实现
  • 鸿蒙版Taro 搭建开发环境
  • 论对生产力决定生产关系的批判:突破决定论的桎梏
  • ESOP交易系统搭建全景指南:从合规基石到价值跃迁
  • GICv3电源管理
  • 《TCP/IP 详解 卷1:协议》第3章:链路层
  • centos 9/ubuntu 一次性的定时关机
  • Elasticsearch从安装到实战、kibana安装以及自定义IK分词器/集成整合SpringBoot详细的教程(二)
  • Java自动类型转换的妙用
  • 数据库管理-第333期 Oracle 23ai:RAC打补丁完全不用停机(20250604)
  • 【DAY39】图像数据与显存
  • AI代码库问答引擎Folda-Scan
  • Kafka深度技术解析:架构、原理与最佳实践
  • 基于cnn的通用图像分类项目
  • Kotlin-协程
  • pycharm 左右箭头 最近编辑
  • Linux环境管道通信介绍
  • DIC技术助力金属管材全场应变测量:高效解决方案
  • python基础day04
  • 嵌入式学习--江协stm32day1
  • 湖北理元理律师事务所:债务化解中的心理重建与法律护航
  • constexpr 是 C++11 引入的关键字
  • 【更新中】(文档+代码)基于推荐算法和Springboot+Vue的购物商城
  • 六种高阶微分方程的特解(原创:daode3056)
  • 【C++11(上)】—— 我与C++的不解之缘(三十)
  • 【多线程初阶】wait() notify()
  • 安全-JAVA开发-第二天