Docker-mysql启动时自动执行SQL

本文介绍了如何在Docker中创建MySQL容器时自动执行SQL脚本,包括创建数据库、表和初始化数据。通过编写docker-entrypoint.sh脚本,并在Dockerfile中拷贝SQL文件到镜像,确保容器启动时自动执行。使用docker-compose启动容器,并通过Navicat验证数据导入成功。
摘要由CSDN通过智能技术生成

说明

在用docker创建mysql容器的时,有时候我们期望容器启动后数据库和表会自动构建,初始化数据也已自动录入,也就是说容器启动后我们就能直接连上容器中的数据库,使用其中的数据了。自动执行SQL这一过程存在于第一次使用镜像构建容器时,下一次restart容器时则不会存在等待其再次自动执行SQL的过程。

其实mysql的官方镜像是支持这个能力的,在容器启动的时候自动执行指定的sql脚本或者shell脚本,我们一起来看看MySQL官方的Dockerfile,如下图:

注意事项:官方加载该sh文件时指定了名字,也就是说,我们的sql启动脚本sh文件也得叫这个名字:docker-entrypoint.sh

快速开始

首先给出项目结构图(使用IDEA):

首先给出SQL文件,一个创建数据库和表sakila-schema.sql,一个写入数据sakila-data.sql:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值