在 Docker 中安裝 MySQL 教程

拉取 MySQL 鏡像

docker pull mysql:8.0

創建并啟動 MySQL 容器

docker run -d \--name mysql8 \-p 3306:3306 \-e MYSQL_ROOT_PASSWORD=123456 \-v mysql_data:/var/lib/mysql \mysql:8.0

命令說明:

-d:后臺運行容器
--name mysql8:給容器起個名字叫 mysql8
-p 3306:3306:將容器的 3306 端口映射到服務器的 3306 端口
-e MYSQL_ROOT_PASSWORD=your_password:設置 root 用戶的密碼,我設置成123456
-v mysql_data:/var/lib/mysql:將數據目錄掛載到卷,確保數據持久化

輸出的一串字符是Docker 容器的唯一 ID

檢查容器是否運行

docker ps

能夠看到MySQL

登錄 MySQL

mysql -u root -p123456

-p后面寫的是自己設置的密碼

出現未找到命令是因為我在宿主機上直接執行了 mysql 命令,但宿主機本身并沒有安裝 MySQL 客戶端工具,我的 MySQL 是安裝在 Docker 容器中的

先進入容器再使用 mysql 命令

使用 docker exec 命令進入容器的 Bash Shell

docker exec -it mysql8 /bin/bash

這里的 mysql8 是之前創建容器時用 --name 指定的名稱

可以看到出現了容器ID

現在再執行登錄命令

mysql -u root -p123456

登錄成功

也可以直接連接 MySQL

可以直接在宿主機執行以下命令,這樣就無需進入容器 Shell

docker exec -it mysql8 mysql -u root -p123456

執行基本 SQL 語句

查看所有數據庫

show databases;

創建一個新數據庫

create database mytestdb;

使用這個數據庫

use mytestdb;

創建一個表

create table students (id int auto_increment primary key,name varchar(50) not null,age int,major varchar(100)
);

在 MySQL 命令行界面中輸入 SQL 語句時,換行不需要特殊的換行符,直接按Enter 鍵即可自動換行。

MySQL 會識別語句是否完整(以分號;結尾),當語句未完成時,按 Enter 鍵會進入續行模式,命令行會顯示->提示符,表示可以繼續輸入下一行內容。

插入數據

insert into students (name, age, major) values 
('張三', 20, '計算機科學'),
('李四', 21, '電子工程'),
('王五', 19, '數學');

查詢數據

select * from students;

更新數據

update students set age = 22 where name = '李四';

刪除數據

delete from students where id = 3;

退出操作

退出 MySQL 命令行:

exit; 或 quit;

退出容器:

exit

常用的容器管理命令

停止 MySQL 容器:
docker stop mysql8啟動 MySQL 容器:
docker start mysql8重啟 MySQL 容器:
docker restart mysql8查看容器日志:
docker logs mysql8

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/96650.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/96650.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/96650.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C#線程理解

目錄 一.線程類 1.基礎線程類(Thread) 2.線程池類(Threadpool) 3.任務并行庫(Task) 4.并行循環(Parallel) 二.線程池(threadPool)和Thread/Task之間的聯系 1.ThreadPool和Thr…

Java入門級教程16——JUC的安全并發包機制

目錄 1.JUC的安全并發包機制 1.1 包含 1.2 Barrier(柵欄)機制——CyclicBarrier(循環屏障) 1.2.1 定義 1.2.2 特性 1.2.1 模擬包車 1.2.2 模擬學生到齊上課 1.2.3 計算任務總耗時 1.3 CountDownLatch(閉鎖)機制 1.3.1 定義 1.3.2 特性 1.3.3…

【網絡通信】全面解析MAC地址:網絡設備的唯一標識

【網絡通信】全面解析MAC地址:網絡設備的唯一標識 文章目錄【網絡通信】全面解析MAC地址:網絡設備的唯一標識前言一、MAC 地址的定義:設備的 “網絡身份證”?二、MAC 地址的格式與組成:48 位的 “數字編碼”?三、MAC 地址的工作…

Perforce Klocwork 2025.2版本更新:默認啟用現代分析引擎、支持 MISRA C:2025 新規、CI構建性能提升等

Perforce Klocwork 現已更新至2025.2版本!該版本增強了對 C/C的分析能力,提升了現代 C 分析的準確性,并改進了對源文件編碼的支持。該版本還為 MISRA C:2025 標準引入了新的分類體系,并增強了 Visual Studio Code 插件的可用性。 …

機器人馭風而行:低空經濟如何開啟智能新紀元【科普類】

新晉碼農一枚,小編會定期整理一些寫的比較好的代碼和知識點,作為自己的學習筆記,試著做一下批注和補充,轉載或者參考他人文獻會標明出處,非商用,如有侵權會刪改!歡迎大家斧正和討論!…

Java學習筆記四(繼承)

1 繼承繼承的實現:public class 子類 extends 父類 {… }注釋:子類可直接使用,父類(保護,公開)的屬性和方法優點:減少重復代碼,缺點:只能單繼承// 父類 public class Tes…

NAT技術:SNAT與DNAT區別詳解

1. 什么是NAT? 定義:NAT 是一種網絡技術,用于在私有網絡(如家庭或企業局域網) 與 公共網絡(如互聯網) 之間轉換IP地址。它允許使用私有IP地址的設備通過一個(或多個)公共…

java語言中,list<String>轉成字符串,逗號分割;List<Integer>轉字符串,逗號分割

java語言中&#xff0c;list<String 轉成字符串&#xff0c;逗號分割 在 Java 中&#xff0c;將 List<String> 轉成逗號分割的字符串有多種方法&#xff1a; 使用 String.join 方法 String.join 是 Java 8 引入的一個靜態方法&#xff0c;它可以方便地將集合中的元素用…

NineData云原生智能數據管理平臺新功能發布|2025年8月版

本月發布 11 項更新&#xff0c;其中重點發布 5項、功能優化 6 項。重點發布數據庫 DevOps - SQL 窗口支持 PolarDB 系列SQL 窗口新增支持 PolarDB PostgreSQL 與 PolarDB Oracle 數據源&#xff0c;擴展云原生數據庫管理能力。新增 AWS 數據源支持新增支持 AWS Aurora Postgre…

【ARDUINO】通過ESP8266連接WIFI,啟動TCP,接受TCP客戶端指令【測試中】

通過ESP8266連接WIFI&#xff0c;啟動TCP&#xff0c;接受TCP客戶端指令**記錄**2025年9月8日11:20:372025年9月9日08:45:342025年9月11日21:40:22**代碼**記錄 2025年9月8日11:20:37 【測試情況】 代碼可以跑到正確連接WIFI&#xff0c;也能獲得IP&#xff0c;但是啟動TCP服…

(網絡原理)核心知識回顧 網絡核心原理 get和post的理解 解析http 加密+請求和響應的一些關鍵字 Cookie和session 對密鑰的理解

目錄 核心知識回顧 網絡核心原理 get和post的理解 解析http 加密請求和響應的一些關鍵字 Cookie和session 對密鑰的理解 核心知識回顧 網絡編程---socket api UDP DatagramSocket DatagramPacket TCP ServerSocket Socket 1.讀寫數據通過Socket,通過Socket內置的 lnpu…

前端框架對比分析:離線PWA + Cloudflare Workers部署

目錄 概述 框架對比表格 詳細分析 1. Astro ????? **強烈推薦** 2. Next.js ???? **推薦** 3. Remix (現React Router) ????? **強烈推薦** 4. SvelteKit ???? **推薦** 5. Nuxt.js ??? **一般推薦** 6. Vite + React ??? **基礎選擇** 推薦方案 ?? …

9-10關于JS初學產生的問題

1.頁面添加加載完成事件監聽&#xff0c;頁面加載完成后&#xff0c;執行頁面初始化方法/函數; 這是什么意思 這句話描述的是前端開發中一種常見的操作&#xff1a;等待頁面完全加載完成后&#xff0c;再執行特定的初始化代碼。 簡單來說&#xff0c;就是要確保頁面上的所有元素…

項目中遇到pom文件里使用systemPath的例子記錄

項目中遇到pom文件里使用systemPath&#xff0c;很少見&#xff0c;問了下豆包&#xff0c;記錄下結果。在 Maven 的 pom.xml 中&#xff0c;<systemPath> 是 <dependency> 標簽內的一個可選配置&#xff0c;用于手動指定本地系統中某個依賴包&#xff08;通常是 J…

10、向量與矩陣基礎 - 深度學習的數學語言

學習目標:建立向量和矩陣的幾何直觀理解,掌握線性代數的核心概念,培養空間思維能力,為手搓大模型奠定扎實的數學基礎 想象一下,當你使用GPT進行對話時,每個詞匯都被轉換成高維向量,整個對話歷史變成一個巨大的矩陣。模型的"理解"過程,本質上就是在這個高維空…

【Python Tkinter】圖形用戶界面(GUI)開發及打包EXE指南

【Python Tkinter】圖形用戶界面&#xff08;GUI&#xff09;開發及打包EXE指南一、關于 Python Tkinter二、密碼生成器示例2.1 使用Python添加圖形用戶界面&#xff08;GUI&#xff09;2.2 使用工具PyInstaller將應用打包成exe文件三、總結一、關于 Python Tkinter Python Tk…

【設計模式】【觀察者模式】實例

一對多的統一監聽 —— 這就是 觀察者模式&#xff08;Observer Pattern&#xff09; 的經典應用場景。也就是說&#xff1a;一個事件源&#xff08;Subject&#xff09; → 可以注冊多個監聽器&#xff08;Observers&#xff09;&#xff1b;當事件發生時&#xff0c;一次性通…

C#測試調用OpenXml操作word文檔的基本用法

OpenXML SDK是微軟為高效處理Office文檔&#xff08;如Word、Excel&#xff09;而開發的開源.NET庫,它直接操作文檔內部的XML結構&#xff0c;無需安裝Office軟件即可實現文檔的創建、讀取和編輯,常用于服務器端批量生成報表、自動化文檔處理等場景&#xff0c;輕量且跨平臺。本…

照度傳感器考慮筆記

您好&#xff01;很高興為您解答關于照度計傳感器和設計的問題。這是一個非常專業且實際的話題。 一、照度計常用的照度傳感器類型 照度計的核心是光電探測器&#xff0c;其工作原理是將光信號轉換為電信號。目前主流的照度傳感器都屬于硅光電二極管&#xff08;Si Photodiode&…

C# Web API Mapster基本使用

安裝包&#xff1a;Mapster1.注冊MyRegister.Scan(); // 全局配置 //builder.Services.AddMapster(); // 需要安裝Mapster.DependencyInjection包 builder.Services.AddScoped<IMapper,Mapper>();2.配置&#xff08;可不進行配置直接使用也行&#xff09;public class My…