【问题标题】:Docker container does now create table on run, MariaDBDocker 容器现在在运行时创建表,MariaDB
【发布时间】:2023-02-01 22:44:26
【问题描述】:

我不确定我在这里做错了什么,但我的 docker 容器 mariadb 在启动时没有创建表。

我究竟做错了什么?

docker-compose.yml

version: '3'
services:
  db:
    build: .
    ports:
      - "3306:3306"
    environment:
      MYSQL_DATABASE: checkitDB
      MYSQL_USER: myuser
      MYSQL_PASSWORD: mypassword
      MYSQL_ROOT_PASSWORD: rootpassword
    volumes:
      - ./initDB:/docker-entrypoint-initdb.d

初始化数据库.sql

CREATE TABLE checkitDB.tasks (
    id VARCHAR(255) NOT NULL,
    title VARCHAR(32) NOT NULL,
    description TEXT NOT NULL,
    PRIMARY KEY (id)
);

【问题讨论】:

    标签: sql docker mariadb


    【解决方案1】:

    这可能有几个原因。

    您是否也有数据库的卷映射? “docker-entrypoint-initdb.d”目录中有“init”,表示脚本仅在数据库初始化时运行。因此,如果您已经有一个数据库,则不会运行脚本。

    另一件事是您映射./initDB,但您的文件名为initDB.sql。如果你只想映射文件,你应该做

    - ./initDB.sql:/docker-entrypoint-initdb.d/initDB.sql
    

    【讨论】:

      猜你喜欢
      • 2022-07-18
      • 2015-04-15
      • 2017-06-01
      • 1970-01-01
      • 1970-01-01
      • 2023-01-07
      • 1970-01-01
      • 1970-01-01
      • 2022-10-04
      相关资源
      最近更新 更多