Mysql導入導出工具Mysqldump和Source命令用法詳解
更新時間:2012年09月16日 00:46:26 作者:
Mysql本身提供了命令行導出工具Mysqldump和Mysql Source導入命令進行SQL數(shù)據(jù)導入導出工作,通過Mysql命令行導出工具Mysqldump命令能夠?qū)ysql數(shù)據(jù)導出為文本格式(txt)的SQL文件,通過Mysql Source命令能夠?qū)QL文件導入Mysql數(shù)據(jù)庫中,下面通過Mysql導入導出SQL實例詳解Mysqldump和Source命令的用法
在PHP網(wǎng)站開發(fā)中,時常遇到Mysql數(shù)據(jù)庫備份或數(shù)據(jù)庫遷移工作,這時Mysql怎么導入導出數(shù)據(jù)庫中的數(shù)據(jù)就非常關(guān)鍵,Mysql本身提供了命令行導出工具Mysqldump和Mysql Source導入命令進行SQL數(shù)據(jù)導入導出工作,通過Mysql命令行導出工具Mysqldump命令能夠?qū)ysql數(shù)據(jù)導出為文本格式(txt)的SQL文件,通過Mysql Source命令能夠?qū)QL文件導入Mysql數(shù)據(jù)庫中,下面通過Mysql導入導出SQL實例詳解Mysqldump和Source命令的用法。
Mysql命令行導出工具Mysqldump命令詳解
Mysql命令行導出工具Mysqldump.exe默認存放在Mysql安裝目錄中的bin子目錄下,在使用Mysqldump導出數(shù)據(jù)庫時,首先請確保Mysql服務(wù)已啟動。
M
ysqldump導出命令基礎(chǔ)用法
默認Mysqldump導出的SQL文件中不但包含了導出的數(shù)據(jù),還包括導出數(shù)據(jù)庫中所有數(shù)據(jù)表的結(jié)構(gòu)信息。
另外使用Mysqldump導出的SQL文件如果不帶絕對路徑,默認是保存在bin目錄下的。
–opt:此Mysqldump命令參數(shù)是可選的,如果帶上這個選項代表激活了Mysqldump命令的quick,add-drop-table,add-locks,extended-insert,lock-tables參數(shù),也就是通過–opt參數(shù)在使用Mysqldump導出Mysql數(shù)據(jù)庫信息時不需要再附加上述這些參數(shù)。
–quick:代表忽略緩沖輸出,Mysqldump命令直接將數(shù)據(jù)導出到指定的SQL文件。
–add-drop-table:顧名思義,就是在每個CREATE TABEL命令之前增加DROP-TABLE IF EXISTS語句,防止數(shù)據(jù)表重名。
–add-locks:表示在INSERT數(shù)據(jù)之前和之后鎖定和解鎖具體的數(shù)據(jù)表,你可以打開Mysqldump導出的SQL文件,在INSERT之前會出現(xiàn)LOCK TABLES和UNLOCK TABLES語句。
–extended-insert (-e):此參數(shù)表示可以多行插入。
更多的Mysqldump命令參數(shù)你可以通過
Mysqldump --help
命令查看Mysqldump包含的所有參數(shù)以及參數(shù)的支持情況。
Mysqldump導出命令實例如下
Mysql數(shù)據(jù)庫安裝后默認包含mysql數(shù)據(jù)庫,我就以此數(shù)據(jù)庫為例來演示Mysqldump的各種導出實例。
使用Mysqldump導出數(shù)據(jù)庫
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --opt mysql >D:\PHPWeb\sqlbackup\mysql.sql
Enter password: ******
使用Mysqldump導出單個表
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --opt mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
使用Mysqldump導出數(shù)據(jù)表結(jié)構(gòu)
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --no-data mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
說明:Mysqldump命令參數(shù) –no-data顧名思義代表Mysqldump導出的數(shù)據(jù)中不含有INSERT數(shù)據(jù),僅僅只是Mysql數(shù)據(jù)庫表user的結(jié)構(gòu)信息。對于這個參數(shù)你也可以使用-d來表示。
使用Mysqldump導出指定條件的數(shù)據(jù)
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p "--where= user= 'root'" mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
說明:在這個Mysqldump導出實例中,通過設(shè)定Mysqldump命令參數(shù) –where=conditions設(shè)定導出的INSERT數(shù)據(jù)條件為user表中user字段為root的INSERT記錄。通過這個參數(shù)你可以根據(jù)需要選用Mysqldump導出自己想要的數(shù)據(jù),非常方便。注意在這個where選項前后都需要使用雙引號,具體的條件可以使用單引號,否則在解析Mysqldump命令行參數(shù)時會出錯,另外你也可以指定多個where參數(shù)。
Mysql數(shù)據(jù)庫導入命令Source詳解
Mysql最常用的數(shù)據(jù)庫導入命令就是Source,Source命令的用法非常簡單,首先你需要進入Mysql數(shù)據(jù)庫的命令行管理界面,然后選擇需要導入的數(shù)據(jù)庫,即
USER 數(shù)據(jù)庫
source 已導出的SQL文件
注意需要導入的SQL文件的具體目錄地址,最好使用/。
至此Mysql命令行導出工具Mysqldump命令以及Mysql導入命令Source的用法就介紹完了,相對于Mysql Source命令,Mysqldump導出功能更豐富,合理利用Mysqldump命令參數(shù)能夠?qū)崿F(xiàn)不同的效果。
mysqldump命令導出數(shù)據(jù)用法詳解
在平時的mysql應(yīng)用中,總會碰到導入數(shù)據(jù),導出數(shù)據(jù),當然有很多方法,這篇文章,主要介紹應(yīng)用mysqlmysqldump命令進行數(shù)據(jù)導入導出,希望對大家有所幫助。
mysqldump命令中帶有一個 --where/-w 參數(shù),它用來設(shè)定數(shù)據(jù)導出的條件,使用方式和SQL查詢命令中中的where基本上相同,有了它,我們就可以從數(shù)據(jù)庫中導出你需要的那部分數(shù)據(jù)了。
1.命令格式如下:
mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫名 表名 --where="篩選條件" > 導出文件路徑
例子:
從test數(shù)據(jù)庫的test_data表中導出id大于100的數(shù)據(jù)到 /tmp/test.sql 這個文件中
mysqldump -uroot -p123456 test test_data --where=" id > 100" > /tmp/test.sql
2.導出整個數(shù)據(jù)庫
mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 > 導出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
3.導出一個數(shù)據(jù)庫結(jié)構(gòu)
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:wcnc_db.sql
-d 沒有數(shù)據(jù) --add-drop-table 在每個create語句之前增加一個drop table
導出庫表(mysqldump)條件
mysqldump -u用戶名 -p密碼 -h主機 數(shù)據(jù)庫 a -w “sql條件” –lock-all-tables > 路徑
1 mysqldump -hhostname -uusername -p dbname tbname>xxxx.sql
** 按指定條件導出數(shù)據(jù)庫表內(nèi)容。(-w選項 –where)
1 mysqldump -hhostname -uusername-p dbname tbname -w'id >= 1 and id<= 10000'--skip-lock-tables > xxxx.sql
或
1 mysqldump -hhostname -uusername -p dbname tbname --where='unit_id >= 1 and unit_id <= 10000'> ~/xxxx.sql
Mysql命令行導出工具Mysqldump命令詳解
Mysql命令行導出工具Mysqldump.exe默認存放在Mysql安裝目錄中的bin子目錄下,在使用Mysqldump導出數(shù)據(jù)庫時,首先請確保Mysql服務(wù)已啟動。
M
ysqldump導出命令基礎(chǔ)用法
復制代碼 代碼如下:
mysqldump -u 用戶名 -p [--opt] DATABASENAME [Table] >導出SQL文件名
默認Mysqldump導出的SQL文件中不但包含了導出的數(shù)據(jù),還包括導出數(shù)據(jù)庫中所有數(shù)據(jù)表的結(jié)構(gòu)信息。
另外使用Mysqldump導出的SQL文件如果不帶絕對路徑,默認是保存在bin目錄下的。
–opt:此Mysqldump命令參數(shù)是可選的,如果帶上這個選項代表激活了Mysqldump命令的quick,add-drop-table,add-locks,extended-insert,lock-tables參數(shù),也就是通過–opt參數(shù)在使用Mysqldump導出Mysql數(shù)據(jù)庫信息時不需要再附加上述這些參數(shù)。
–quick:代表忽略緩沖輸出,Mysqldump命令直接將數(shù)據(jù)導出到指定的SQL文件。
–add-drop-table:顧名思義,就是在每個CREATE TABEL命令之前增加DROP-TABLE IF EXISTS語句,防止數(shù)據(jù)表重名。
–add-locks:表示在INSERT數(shù)據(jù)之前和之后鎖定和解鎖具體的數(shù)據(jù)表,你可以打開Mysqldump導出的SQL文件,在INSERT之前會出現(xiàn)LOCK TABLES和UNLOCK TABLES語句。
–extended-insert (-e):此參數(shù)表示可以多行插入。
更多的Mysqldump命令參數(shù)你可以通過
復制代碼 代碼如下:
Mysqldump --help
命令查看Mysqldump包含的所有參數(shù)以及參數(shù)的支持情況。
Mysqldump導出命令實例如下
Mysql數(shù)據(jù)庫安裝后默認包含mysql數(shù)據(jù)庫,我就以此數(shù)據(jù)庫為例來演示Mysqldump的各種導出實例。
使用Mysqldump導出數(shù)據(jù)庫
復制代碼 代碼如下:
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --opt mysql >D:\PHPWeb\sqlbackup\mysql.sql
Enter password: ******
使用Mysqldump導出單個表
復制代碼 代碼如下:
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --opt mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
使用Mysqldump導出數(shù)據(jù)表結(jié)構(gòu)
復制代碼 代碼如下:
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p --no-data mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
說明:Mysqldump命令參數(shù) –no-data顧名思義代表Mysqldump導出的數(shù)據(jù)中不含有INSERT數(shù)據(jù),僅僅只是Mysql數(shù)據(jù)庫表user的結(jié)構(gòu)信息。對于這個參數(shù)你也可以使用-d來表示。
使用Mysqldump導出指定條件的數(shù)據(jù)
復制代碼 代碼如下:
C:\Program Files\MySQL\MySQL Server 5.1\bin>mysqldump -u root -p "--where= user= 'root'" mysql user >D:\PHPWeb\sqlbackup\mysql_user.sql
Enter password: ******
說明:在這個Mysqldump導出實例中,通過設(shè)定Mysqldump命令參數(shù) –where=conditions設(shè)定導出的INSERT數(shù)據(jù)條件為user表中user字段為root的INSERT記錄。通過這個參數(shù)你可以根據(jù)需要選用Mysqldump導出自己想要的數(shù)據(jù),非常方便。注意在這個where選項前后都需要使用雙引號,具體的條件可以使用單引號,否則在解析Mysqldump命令行參數(shù)時會出錯,另外你也可以指定多個where參數(shù)。
Mysql數(shù)據(jù)庫導入命令Source詳解
Mysql最常用的數(shù)據(jù)庫導入命令就是Source,Source命令的用法非常簡單,首先你需要進入Mysql數(shù)據(jù)庫的命令行管理界面,然后選擇需要導入的數(shù)據(jù)庫,即
復制代碼 代碼如下:
USER 數(shù)據(jù)庫
source 已導出的SQL文件
注意需要導入的SQL文件的具體目錄地址,最好使用/。
至此Mysql命令行導出工具Mysqldump命令以及Mysql導入命令Source的用法就介紹完了,相對于Mysql Source命令,Mysqldump導出功能更豐富,合理利用Mysqldump命令參數(shù)能夠?qū)崿F(xiàn)不同的效果。
mysqldump命令導出數(shù)據(jù)用法詳解
在平時的mysql應(yīng)用中,總會碰到導入數(shù)據(jù),導出數(shù)據(jù),當然有很多方法,這篇文章,主要介紹應(yīng)用mysqlmysqldump命令進行數(shù)據(jù)導入導出,希望對大家有所幫助。
mysqldump命令中帶有一個 --where/-w 參數(shù),它用來設(shè)定數(shù)據(jù)導出的條件,使用方式和SQL查詢命令中中的where基本上相同,有了它,我們就可以從數(shù)據(jù)庫中導出你需要的那部分數(shù)據(jù)了。
1.命令格式如下:
mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫名 表名 --where="篩選條件" > 導出文件路徑
例子:
從test數(shù)據(jù)庫的test_data表中導出id大于100的數(shù)據(jù)到 /tmp/test.sql 這個文件中
復制代碼 代碼如下:
mysqldump -uroot -p123456 test test_data --where=" id > 100" > /tmp/test.sql
2.導出整個數(shù)據(jù)庫
mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 > 導出的文件名
復制代碼 代碼如下:
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
3.導出一個數(shù)據(jù)庫結(jié)構(gòu)
復制代碼 代碼如下:
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:wcnc_db.sql
-d 沒有數(shù)據(jù) --add-drop-table 在每個create語句之前增加一個drop table
導出庫表(mysqldump)條件
mysqldump -u用戶名 -p密碼 -h主機 數(shù)據(jù)庫 a -w “sql條件” –lock-all-tables > 路徑
復制代碼 代碼如下:
1 mysqldump -hhostname -uusername -p dbname tbname>xxxx.sql
** 按指定條件導出數(shù)據(jù)庫表內(nèi)容。(-w選項 –where)
1 mysqldump -hhostname -uusername-p dbname tbname -w'id >= 1 and id<= 10000'--skip-lock-tables > xxxx.sql
或
1 mysqldump -hhostname -uusername -p dbname tbname --where='unit_id >= 1 and unit_id <= 10000'> ~/xxxx.sql
相關(guān)文章
安裝mysql-8.0.19-winx64遇到的問題:Can''t create directory ''xxxx\Da
這篇文章主要介紹了安裝mysql-8.0.19-winx64遇到的坑 ,Can't create directory 'xxxx\Database\',非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02
mysql8報錯:ERROR?1410?(42000):?You?are?not?allowed?to?
電腦新裝的mysql,版本為8.0以上,分配權(quán)限時直接帶密碼和賬號會報錯,這篇文章主要給大家介紹了關(guān)于mysql8報錯:ERROR?1410?(42000):?You?are?not?allowed?to?create?a?user?with?GRANT的解決辦法,需要的朋友可以參考下2022-06-06
mysql自動備份多個數(shù)據(jù)庫的實現(xiàn)
本文主要介紹了mysql自動備份多個數(shù)據(jù)庫的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07
win10家庭版64位下mysql 8.0.15 安裝配置方法圖文教程
這篇文章主要為大家詳細介紹了win10家庭版64位下mysql 8.0.15 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-03-03
Mysql匿名登錄無法創(chuàng)建數(shù)據(jù)庫問題解決方案
這篇文章主要介紹了Mysql匿名登錄無法創(chuàng)建數(shù)據(jù)庫問題解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-12-12
mysql觸發(fā)器之創(chuàng)建多個觸發(fā)器操作實例分析
這篇文章主要介紹了mysql觸發(fā)器之創(chuàng)建多個觸發(fā)器操作,結(jié)合實例形式分析了mysql創(chuàng)建及使用多個觸發(fā)器的相關(guān)操作技巧,需要的朋友可以參考下2019-12-12
MySQL中dd::columns表結(jié)構(gòu)轉(zhuǎn)table過程及應(yīng)用詳解
MySQL的dd表是用來存放表結(jié)構(gòu)和各種建表信息的,客戶端建的表都存在mysql.table和mysql.columns表里,還有一個表mysql.column_type_elements比較特殊,用來存放SET和ENUM類型的字段集合值信息,對mysql dd::columns表結(jié)構(gòu)相關(guān)知識感興趣的朋友一起看看吧2022-09-09

