mysql如何將數(shù)據(jù)庫中的所有表結(jié)構(gòu)和數(shù)據(jù)導(dǎo)入到另一個庫
一、問題描述
- 在本地開發(fā)一個功能,需要結(jié)合具體數(shù)據(jù)測試代碼是否正確,但服務(wù)器上的數(shù)據(jù)不可隨便修改。此時則需要將服務(wù)器上某個數(shù)據(jù)庫的表批量導(dǎo)入到本地、而后進(jìn)行測試。
- 將數(shù)據(jù)庫db1中的所有表及數(shù)據(jù)(如table1、table2),批量導(dǎo)入到另一個數(shù)據(jù)庫db2中。
二、解決方案
剛開始自己一直嘗試用DataGrip、Navicat的sql/csv格式導(dǎo)入導(dǎo)出,總有錯誤或者遺漏,比如報錯中止、50張表卻只導(dǎo)入32張等,可能是操作方式有誤或者數(shù)據(jù)格式有問題。
也試過用sql語句,但仍失敗。經(jīng)查閱資料、嘗試多次,終于成功,記錄如下。
1.使用mysqldump命令備份數(shù)據(jù)庫
首先使用mysqldump命令來備份源數(shù)據(jù)庫。
mysqldump是MySQL自帶的命令行工具,可通過在cmd(windows)或 Linux終端(Linux)中執(zhí)行如下命令來備份整個數(shù)據(jù)庫:
mysqldump -u <username> -p <database_name> > backup.sql
其中,是數(shù)據(jù)庫的用戶名,<database_name>是要備份的數(shù)據(jù)庫的名稱,backup.sql是備份文件的名稱。
執(zhí)行完該命令后,會在當(dāng)前目錄生成一個名為backup.sql的文件,該文件包含了源數(shù)據(jù)庫的所有表結(jié)構(gòu)和數(shù)據(jù)。
其他的一些導(dǎo)出語句,可參考以下:
//導(dǎo)出完整數(shù)據(jù)庫結(jié)構(gòu)和數(shù)據(jù) mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 > 導(dǎo)出的文件名 //導(dǎo)出數(shù)據(jù)庫結(jié)構(gòu) mysqldump -u 用戶名 -p -d 數(shù)據(jù)庫名 > 導(dǎo)出的文件名 //導(dǎo)出一個表,包括表結(jié)構(gòu)和數(shù)據(jù) mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 表名> 導(dǎo)出的文件名 //導(dǎo)出一個表結(jié)構(gòu) mysqldump -u 用戶名 -p -d數(shù)據(jù)庫名 表名> 導(dǎo)出的文件名
注:
建議使用mysqldump備份數(shù)據(jù)庫,能完整保留源數(shù)據(jù)庫的結(jié)構(gòu)和數(shù)據(jù)。
DataGrip、Navicat的導(dǎo)入導(dǎo)出,由于兩個數(shù)據(jù)庫之間可能存在差異,數(shù)據(jù)結(jié)構(gòu)、格式會發(fā)生改變,導(dǎo)致復(fù)制失敗。
2.創(chuàng)建目標(biāo)數(shù)據(jù)庫
需要在目標(biāo)數(shù)據(jù)庫中創(chuàng)建對應(yīng)的數(shù)據(jù)庫,可以使用MySQL的命令行工具登錄到目標(biāo)數(shù)據(jù)庫,執(zhí)行以下命令來創(chuàng)建數(shù)據(jù)庫:
create database <database_name>;
其中,<database_name>是目標(biāo)數(shù)據(jù)庫的名稱。
3.導(dǎo)入數(shù)據(jù) 到目標(biāo)數(shù)據(jù)庫
有了源數(shù)據(jù)庫的備份文件和目標(biāo)數(shù)據(jù)庫,可以使用MySQL的命令行工具將備份的sql語句導(dǎo)入到目標(biāo)數(shù)據(jù)庫。
進(jìn)入backup.sql所在目錄(如果是從服務(wù)器導(dǎo)入到本機(jī) 可將服務(wù)器上生成的backup.sql文件下載到本地),在目標(biāo)數(shù)據(jù)庫的終端執(zhí)行以下命令:
mysql -u <username> -p <database_name> < backup.sql
其中,是目標(biāo)數(shù)據(jù)庫的用戶名,<database_name>是目標(biāo)數(shù)據(jù)庫的名稱,backup.sql是源數(shù)據(jù)庫的備份文件。
執(zhí)行完該命令后,目標(biāo)數(shù)據(jù)庫將包含與源數(shù)據(jù)庫完全相同的所有表結(jié)構(gòu)和數(shù)據(jù)。
三、補(bǔ)充知識
3.1 mysqldump命令介紹
[root@localhost ~]# mysqldump -help Usage: mysqldump [OPTIONS] database [tables] OR mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...] OR mysqldump [OPTIONS] --all-databases [OPTIONS] For more options, use mysqldump --help
登錄選項
1.登錄選項: -u user:指定用戶 -h host:指定主機(jī) -p:表示要使用密碼 -E, --events: 備份事件調(diào)度器 -R, --routines: 備份存儲過程和存儲函數(shù) 2.備份選項: --all-databases:備份所有數(shù)據(jù)庫 --databases db1 db2:備份指定的數(shù)據(jù)庫 --single-transaction:對事務(wù)引擎執(zhí)行熱備 --flush-logs:更新二進(jìn)制日志文件 --master-data=2 1:每備份一個庫就生成一個新的二進(jìn)制文件(默認(rèn)) 2:只生成一個新的二進(jìn)制文件 --quick:在備份大表時指定該選項
3.2 常用備份命令
//導(dǎo)出命令 #導(dǎo)出包括系統(tǒng)數(shù)據(jù)庫在內(nèi)的所有數(shù)據(jù)庫(all.sql默認(rèn)保存在bin文件夾下面) mysqldump -u username -p --all-databases > filename.sql #導(dǎo)出指定數(shù)據(jù)庫表結(jié)構(gòu)和數(shù)據(jù) mysqldump -u username -p dbname [tbname...] > filename.sql #導(dǎo)出多個數(shù)據(jù)庫: mysqldump -u username -p --databases db1 db2 ...> filename.sql #導(dǎo)出多張表: mysqldump -u username -p --databases db1 --tables t1 t2> filename.sql #只導(dǎo)出表結(jié)構(gòu)不導(dǎo)表數(shù)據(jù),添加“-d”命令參數(shù) mysqldump -u username -p -d dbname [tbname...] > filename.sql #只導(dǎo)出表數(shù)據(jù)不導(dǎo)表結(jié)構(gòu),添加“-t”命令參數(shù) mysqldump -u username -p -t dbname [tbname...] > d:/user.sql #只導(dǎo)出db1數(shù)據(jù)庫的表結(jié)構(gòu) 導(dǎo)出:mysqldump -u root -p --no-data --databases db1 > backup.sql 導(dǎo)入:mysql -u root -p db1 < backup.sql #系統(tǒng)行導(dǎo)入命令 mysql -u username -p dbname < d:XX.sql(路徑) mysql -u root -p db_name < d:/backup.sql #source導(dǎo)入 mysql> use db_name; mysql> source /backup/mysqldump/backup.sql(路徑)
參數(shù)說明:
username
:表示用戶名稱;dbname
:表示需要備份的數(shù)據(jù)庫名稱;tbname
:表示數(shù)據(jù)庫中需要備份的數(shù)據(jù)表,可以指定多個數(shù)據(jù)表。省略該參數(shù)時,會備份整個數(shù)據(jù)庫;右箭頭“>”
:用來告訴 mysqldump 將備份數(shù)據(jù)表的定義和數(shù)據(jù)寫入備份文件;filename.sql
:表示備份文件的名稱,文件名前面可以加絕對路徑。通常將數(shù)據(jù)庫備份成一個后綴名為.sql的文件。
注意:
mysqldump 命令必須在 cmd 窗口下執(zhí)行,不能登錄到 MySQL 服務(wù)中執(zhí)行。
輸入密碼后,Mysql就會進(jìn)行備份了。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- MySQL查詢數(shù)據(jù)庫所有表名以及表結(jié)構(gòu)其注釋(小白專用)
- mysql將數(shù)據(jù)庫中所有表結(jié)構(gòu)和數(shù)據(jù)導(dǎo)入到另一個庫的方法(親測有效)
- MySQL數(shù)據(jù)庫線上修改表結(jié)構(gòu)的方法
- 利用Python批量導(dǎo)出mysql數(shù)據(jù)庫表結(jié)構(gòu)的操作實例
- mysql如何比對兩個數(shù)據(jù)庫表結(jié)構(gòu)的方法
- MYSQL數(shù)據(jù)庫表結(jié)構(gòu)優(yōu)化方法詳解
- 詳解 linux mysqldump 導(dǎo)出數(shù)據(jù)庫、數(shù)據(jù)、表結(jié)構(gòu)
相關(guān)文章
Windows下MySQL8.0.11社區(qū)綠色版安裝步驟圖解
在本教程中使用MySQL最新的MySQL服務(wù)8.0.11的社區(qū)綠色版本進(jìn)行安裝,綠色版為zip格式的包,安裝步驟分為四大步驟,具體哪四大步驟大家跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05navicat如何利用sql語句查詢表所有字段的字段名、類型及長度
Navicat使用了極好的圖形用戶界面(GUI),可以讓你用一種安全和更為容易的方式快速和容易地創(chuàng)建、組織、存取和共享信息,下面這篇文章主要給大家介紹了關(guān)于navicat如何利用sql語句查詢表所有字段的字段名、類型及長度的相關(guān)資料,需要的朋友可以參考下2023-05-05MySQL數(shù)據(jù)庫遷移OpenGauss數(shù)據(jù)庫解析
這篇文章主要介紹了MySQL數(shù)據(jù)庫遷移OpenGauss數(shù)據(jù)庫解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09