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

完整教程: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:pg16    container_name: my-postgres    environment:      POSTGRES_PASSWORD: root    ports:      - "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.sql    restart: 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.jsqmd.com/news/9523/

相关文章:

  • vscode的文心快码插件不错
  • EPU+VPU+WBUC+WAUC:AI元人文的硅基基石体系
  • Educational Codeforces Round 183 (Rated for Div. 2)题解
  • 股市技术分析突破
  • 干货分享:无需下载,在线快速编辑图片的完整教程
  • 34.1STM32下的can总线实现知识(区分linux)_csdn - 详解
  • js实现promise常用场景使用示例
  • spatial for parallel compute 使用简介
  • Mermaid 绘图--以企业权限视图为例 - 详解
  • 英语_阅读_Balancing Benefits and Risks_待读
  • 读技术之外:社会联结中的人工智能02劳工
  • 详细介绍:如何有效删除 iPhone 上的所有内容?
  • 鼠标图标更改样式
  • webpack和vite的区别 - 指南
  • m3u8在线播放测试的方法与常见问题解决方案(附网页演示
  • 校招题
  • React 播客专栏 Vol.18|React 第二阶段复习 样式与 Hooks 全面整合 - 实践
  • Manim实现旋转扭曲特效
  • go语言学习 第5章:函数 - 详解
  • 混沌熵池:“创造之源”还是“皇帝的新衣”?
  • 完整教程:Go语言使用阿里云模版短信服务
  • 计算机网络物理层基础练习 - 详解
  • KaTeX手册
  • Qt编写上下界面切换效果/前进到下一个界面/后退到上一个页面/零件工艺及管理设计系统
  • 【题解】P1131 [ZJOI2007] 时态同步
  • LGP9120 [NOIP 2022.5] 密码锁 学习笔记
  • 深入解析:OpenCV CUDA模块图像处理------创建CUDA加速的Canny边缘检测器对象createCannyEdgeDetector()
  • 机器人技术奖学金项目助力STEM教育发展
  • busybox 没有 clear 命令吗
  • 实用指南:Hive SQL 中 BY 系列关键字全解析:从排序、分发到分组的核心用法