在docker中的mysql容器內(nèi)執(zhí)行命令與執(zhí)行SQL文件方式
docker的mysql容器內(nèi)執(zhí)行命令與執(zhí)行SQL文件
通過 docker ps -a 查詢當(dāng)前運行的容器,找到想執(zhí)行命令的容器名稱。
docker ps -a
若想執(zhí)行sql文件,則將sql文件放入當(dāng)前文件夾下后將項目內(nèi)的 SQL 文件拷貝到 mysql 容器內(nèi)部的 root下。
sudo docker cp /root/enterprise.sql mysql:/root/
然后進入 mysql 容器內(nèi)部。
docker exec -it mysql /bin/bash
進入mysql容器內(nèi)部執(zhí)行以下命令后回車,輸入數(shù)據(jù)庫密碼進入 mysql 數(shù)據(jù)庫
mysql -u root -p
如圖:
切換到對應(yīng)的數(shù)據(jù)庫下,例如數(shù)據(jù)庫 zd,記得后面要加分號
use zd;
現(xiàn)在就可以對此數(shù)據(jù)庫執(zhí)行相關(guān)命令了,若想執(zhí)行sql文件,則運行以下命令,_/root/enterprise.sql_為剛剛復(fù)制進來的文件路徑,具體路徑請根據(jù)個人調(diào)整。
source /root/enterprise.sql
如果沒有出現(xiàn)報錯,則此sql文件執(zhí)行成功!
以下是mysql常用命令:
MySQL清空表數(shù)據(jù)三種方法
1.1 清空表數(shù)據(jù):truncate
sql命令:
#清空多張表、庫中所有表的數(shù)據(jù) truncate table table_name1,table_name2,...; #清空單張表的數(shù)據(jù) truncate table table_name;
注意:
- truncate會刪除表中的所有數(shù)據(jù)、釋放空間,但是保留表結(jié)構(gòu) 只能操作表,不能與where一起使用
- truncate刪除操作立即生效,原數(shù)據(jù)不放到rollback segment中,不能rollback,操作不觸發(fā)trigger
- truncate刪除數(shù)據(jù)后會釋放表空間、重置Identity(標(biāo)識列、自增字段),相當(dāng)于自增列會被置為初始值,又重新從1開始記錄、而非接著原來的id數(shù)
- truncate刪除數(shù)據(jù)后不寫服務(wù)器log,整體刪除速度快
1.2 刪除表:drop
sql命令:
drop table table_name; drop table if exists table_name;
注意:
- drop會刪除整個表,包括表結(jié)構(gòu)和數(shù)據(jù),釋放空間
- 立即執(zhí)行,執(zhí)行速度最快
- 不可回滾
1.3 刪除/清空表數(shù)據(jù):delete
sql命令:
#刪除部分?jǐn)?shù)據(jù) delete from tb_name where clause; #清空表,僅刪除數(shù)據(jù)、保留表結(jié)構(gòu),同時也不釋放表空間 delete from tb_name;
注意:
- 刪除表中數(shù)據(jù)而不刪除表結(jié)構(gòu),也不釋放空間
- delete可以刪除一行、多行、乃至整張表
- 每次刪除一行,都在事務(wù)日志中為所刪除的每行記錄一項,可回滾
- 如果不加where條件,表示刪除表中所有數(shù)據(jù),僅刪除數(shù)據(jù)、保留表結(jié)構(gòu),同時也不釋放表空間
MySQL、Mariadb、PostgreSQL刪除表數(shù)據(jù)、清空表命令 都可用以上三種命令。
使用原則
使用原則總結(jié)如下:
- 當(dāng)你不需要該表時(刪除數(shù)據(jù)和結(jié)構(gòu)),用drop;
- 當(dāng)你仍要保留該表、僅刪除所有數(shù)據(jù)表內(nèi)容時,用truncate;
- 當(dāng)你要刪除部分記錄、且希望能回滾的話,用delete;
在沒有備份的情況下,謹(jǐn)慎使用drop、truncate。
在實際應(yīng)用中,要根據(jù)具體需求和場景選擇合適的操作。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Docker端口映射實現(xiàn)網(wǎng)絡(luò)訪問的方法
本篇文章主要介紹了Docker端口映射實現(xiàn)網(wǎng)絡(luò)訪問的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07Docker網(wǎng)段和內(nèi)網(wǎng)網(wǎng)段ip沖突導(dǎo)致無法訪問網(wǎng)絡(luò)的兩種解決方法
本文主要介紹了Docker網(wǎng)段和內(nèi)網(wǎng)網(wǎng)段沖突導(dǎo)致無法訪問網(wǎng)絡(luò)的兩種解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06docker?swarm快速部署redis分布式集群的詳細(xì)過程
這篇文章主要介紹了docker?swarm快速部署redis分布式集群,只需要通過docker-compose.yml文件和一個啟動命令就完成redis分布式部署的方式,讓其分別部署在不同機器上,并實現(xiàn)集群搭建,需要的朋友可以參考下2022-10-10