欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql如何將數(shù)據(jù)庫中的所有表結(jié)構(gòu)和數(shù)據(jù)導(dǎo)入到另一個庫

 更新時間:2024年10月11日 08:59:48   作者:尋求出路的程序媛  
介紹了如何使用mysqldump命令備份和導(dǎo)入數(shù)據(jù)庫,以及創(chuàng)建目標(biāo)數(shù)據(jù)庫的步驟,首先使用mysqldump備份源數(shù)據(jù)庫,然后在目標(biāo)數(shù)據(jù)庫中創(chuàng)建數(shù)據(jù)庫,并將備份文件導(dǎo)入到目標(biāo)數(shù)據(jù)庫,確保數(shù)據(jù)結(jié)構(gòu)和內(nèi)容完整復(fù)制,提到了DataGrip、Navicat在導(dǎo)入導(dǎo)出過程中可能出現(xiàn)的問題

一、問題描述

  • 在本地開發(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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql中between的邊界,范圍說明

    mysql中between的邊界,范圍說明

    這篇文章主要介紹了mysql中between的邊界,范圍說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Windows下MySQL8.0.11社區(qū)綠色版安裝步驟圖解

    Windows下MySQL8.0.11社區(qū)綠色版安裝步驟圖解

    在本教程中使用MySQL最新的MySQL服務(wù)8.0.11的社區(qū)綠色版本進(jìn)行安裝,綠色版為zip格式的包,安裝步驟分為四大步驟,具體哪四大步驟大家跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • mysql修改用戶密碼報錯的解決方法

    mysql修改用戶密碼報錯的解決方法

    mysql 初始化時,使用臨時密碼,修改自定義密碼時,由于自定義密碼比較簡單,就出現(xiàn)了不符合密碼策略的問題,這篇文章主要介紹了mysql修改用戶密碼報錯,需要的朋友可以參考下
    2023-03-03
  • mysql存儲過程中使用游標(biāo)的實例

    mysql存儲過程中使用游標(biāo)的實例

    使用MYSQL存儲過程,可以實現(xiàn)諸多的功能,下面將為您介紹一個MYSQL存儲過程中使用游標(biāo)的實例
    2014-01-01
  • MySQL 用 limit 為什么會影響性能

    MySQL 用 limit 為什么會影響性能

    對于小的偏移量,直接使用limit來查詢沒有什么問題,但隨著數(shù)據(jù)量的增大,越往后分頁,limit語句的偏移量就會越大,速度也會明顯變慢,接下來文章就向大家介紹其的原由,感興趣的小伙伴可參考下面文章具體內(nèi)容
    2021-09-09
  • 探究MySQL優(yōu)化器對索引和JOIN順序的選擇

    探究MySQL優(yōu)化器對索引和JOIN順序的選擇

    這篇文章主要介紹了探究MySQL優(yōu)化器對索引和JOIN順序的選擇,包括在優(yōu)化器做出錯誤判斷時的選擇情況,需要的朋友可以參考下
    2015-05-05
  • navicat如何利用sql語句查詢表所有字段的字段名、類型及長度

    navicat如何利用sql語句查詢表所有字段的字段名、類型及長度

    Navicat使用了極好的圖形用戶界面(GUI),可以讓你用一種安全和更為容易的方式快速和容易地創(chuàng)建、組織、存取和共享信息,下面這篇文章主要給大家介紹了關(guān)于navicat如何利用sql語句查詢表所有字段的字段名、類型及長度的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • MySQL數(shù)據(jù)庫遷移OpenGauss數(shù)據(jù)庫解析

    MySQL數(shù)據(jù)庫遷移OpenGauss數(shù)據(jù)庫解析

    這篇文章主要介紹了MySQL數(shù)據(jù)庫遷移OpenGauss數(shù)據(jù)庫解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • mysql VARCHAR的最大長度到底是多少

    mysql VARCHAR的最大長度到底是多少

    今天群里有人問varchar 不是最大應(yīng)該只可以設(shè)置65532(第一個字節(jié)+兩個長度字節(jié))嗎 ,但是為什么可以設(shè)置成65533
    2012-10-10
  • MySQL修改賬號密碼方法大全(小結(jié))

    MySQL修改賬號密碼方法大全(小結(jié))

    這篇文章主要介紹了MySQL修改賬號密碼方法大全(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12

最新評論