Mysql本身提供了命令行導(dǎo)出工具Mysqldump和Mysql Source導(dǎo)入命令進行SQL數(shù)據(jù)導(dǎo)入導(dǎo)出工作,通過Mysql命令行導(dǎo)出工具Mysqldump命令能夠?qū)ysql數(shù)據(jù)導(dǎo)出為文本格式(txt)的SQL文件,通過Mysql Source命令能夠?qū)QL文件導(dǎo)入Mysql數(shù)據(jù)庫中,下面通過Mysql導(dǎo)入導(dǎo)出SQL實例詳解Mysqldump和Source命令的用法
?
在PHP網(wǎng)站開發(fā)中,時常遇到Mysql數(shù)據(jù)庫備份或數(shù)據(jù)庫遷移工作,這時Mysql怎么導(dǎo)入導(dǎo)出數(shù)據(jù)庫中的數(shù)據(jù)就非常關(guān)鍵,Mysql本身提供了命令行導(dǎo)出工具Mysqldump和Mysql Source導(dǎo)入命令進行SQL數(shù)據(jù)導(dǎo)入導(dǎo)出工作,通過Mysql命令行導(dǎo)出工具Mysqldump命令能夠?qū)ysql數(shù)據(jù)導(dǎo)出為文本格式(txt)的SQL文件,通過Mysql Source命令能夠?qū)QL文件導(dǎo)入Mysql數(shù)據(jù)庫中,下面通過Mysql導(dǎo)入導(dǎo)出SQL實例詳解Mysqldump和Source命令的用法。
Mysql命令行導(dǎo)出工具Mysqldump命令詳解
Mysql命令行導(dǎo)出工具Mysqldump.exe默認存放在Mysql安裝目錄中的bin子目錄下,在使用Mysqldump導(dǎo)出數(shù)據(jù)庫時,首先請確保Mysql服務(wù)已啟動。
M
ysqldump導(dǎo)出命令基礎(chǔ)用法
默認Mysqldump導(dǎo)出的SQL文件中不但包含了導(dǎo)出的數(shù)據(jù),還包括導(dǎo)出數(shù)據(jù)庫中所有數(shù)據(jù)表的結(jié)構(gòu)信息。
另外使用Mysqldump導(dǎo)出的SQL文件如果不帶絕對路徑,默認是保存在bin目錄下的。
–opt:此Mysqldump命令參數(shù)是可選的,如果帶上這個選項代表激活了Mysqldump命令的quick,add-drop-table,add-locks,extended-insert,lock-tables參數(shù),也就是通過–opt參數(shù)在使用Mysqldump導(dǎo)出Mysql數(shù)據(jù)庫信息時不需要再附加上述這些參數(shù)。
–quick:代表忽略緩沖輸出,Mysqldump命令直接將數(shù)據(jù)導(dǎo)出到指定的SQL文件。
–add-drop-table:顧名思義,就是在每個CREATE TABEL命令之前增加DROP-TABLE IF EXISTS語句,防止數(shù)據(jù)表重名。
–add-locks:表示在INSERT數(shù)據(jù)之前和之后鎖定和解鎖具體的數(shù)據(jù)表,你可以打開Mysqldump導(dǎo)出的SQL文件,在INSERT之前會出現(xiàn)LOCK TABLES和UNLOCK TABLES語句。
–extended-insert (-e):此參數(shù)表示可以多行插入。
更多的Mysqldump命令參數(shù)你可以通過
Mysqldump --help
命令查看Mysqldump包含的所有參數(shù)以及參數(shù)的支持情況。
Mysqldump導(dǎo)出命令實例如下
Mysql數(shù)據(jù)庫安裝后默認包含mysql數(shù)據(jù)庫,我就以此數(shù)據(jù)庫為例來演示Mysqldump的各種導(dǎo)出實例。
使用Mysqldump導(dǎo)出數(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導(dǎo)出單個表
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導(dǎo)出數(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導(dǎo)出的數(shù)據(jù)中不含有INSERT數(shù)據(jù),僅僅只是Mysql數(shù)據(jù)庫表user的結(jié)構(gòu)信息。對于這個參數(shù)你也可以使用-d來表示。
使用Mysqldump導(dǎo)出指定條件的數(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導(dǎo)出實例中,通過設(shè)定Mysqldump命令參數(shù) –where=conditions設(shè)定導(dǎo)出的INSERT數(shù)據(jù)條件為user表中user字段為root的INSERT記錄。通過這個參數(shù)你可以根據(jù)需要選用Mysqldump導(dǎo)出自己想要的數(shù)據(jù),非常方便。注意在這個where選項前后都需要使用雙引號,具體的條件可以使用單引號,否則在解析Mysqldump命令行參數(shù)時會出錯,另外你也可以指定多個where參數(shù)。
Mysql數(shù)據(jù)庫導(dǎo)入命令Source詳解
Mysql最常用的數(shù)據(jù)庫導(dǎo)入命令就是Source,Source命令的用法非常簡單,首先你需要進入Mysql數(shù)據(jù)庫的命令行管理界面,然后選擇需要導(dǎo)入的數(shù)據(jù)庫,即
USER 數(shù)據(jù)庫
source 已導(dǎo)出的SQL文件
注意需要導(dǎo)入的SQL文件的具體目錄地址,最好使用/。
至此Mysql命令行導(dǎo)出工具Mysqldump命令以及Mysql導(dǎo)入命令Source的用法就介紹完了,相對于Mysql Source命令,Mysqldump導(dǎo)出功能更豐富,合理利用Mysqldump命令參數(shù)能夠?qū)崿F(xiàn)不同的效果。
mysqldump命令導(dǎo)出數(shù)據(jù)用法詳解
在平時的mysql應(yīng)用中,總會碰到導(dǎo)入數(shù)據(jù),導(dǎo)出數(shù)據(jù),當然有很多方法,這篇文章,主要介紹應(yīng)用mysqlmysqldump命令進行數(shù)據(jù)導(dǎo)入導(dǎo)出,希望對大家有所幫助。
mysqldump命令中帶有一個 --where/-w 參數(shù),它用來設(shè)定數(shù)據(jù)導(dǎo)出的條件,使用方式和SQL查詢命令中中的where基本上相同,有了它,我們就可以從數(shù)據(jù)庫中導(dǎo)出你需要的那部分數(shù)據(jù)了。
1.命令格式如下:
mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫名 表名 --where="篩選條件" > 導(dǎo)出文件路徑
例子:
從test數(shù)據(jù)庫的test_data表中導(dǎo)出id大于100的數(shù)據(jù)到 /tmp/test.sql 這個文件中
mysqldump -uroot -p123456 test test_data --where=" id > 100" > /tmp/test.sql
2.導(dǎo)出整個數(shù)據(jù)庫
mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 > 導(dǎo)出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
3.導(dǎo)出一個數(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
導(dǎo)出庫表(mysqldump)條件
mysqldump -u用戶名 -p密碼 -h主機 數(shù)據(jù)庫 a -w “sql條件” –lock-all-tables > 路徑
1 mysqldump -hhostname -uusername -p dbname tbname>xxxx.sql
** 按指定條件導(dǎo)出數(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命令行導(dǎo)出工具Mysqldump命令詳解
Mysql命令行導(dǎo)出工具Mysqldump.exe默認存放在Mysql安裝目錄中的bin子目錄下,在使用Mysqldump導(dǎo)出數(shù)據(jù)庫時,首先請確保Mysql服務(wù)已啟動。
M
ysqldump導(dǎo)出命令基礎(chǔ)用法
mysqldump -u 用戶名 -p [--opt] DATABASENAME [Table] >導(dǎo)出SQL文件名
默認Mysqldump導(dǎo)出的SQL文件中不但包含了導(dǎo)出的數(shù)據(jù),還包括導(dǎo)出數(shù)據(jù)庫中所有數(shù)據(jù)表的結(jié)構(gòu)信息。
另外使用Mysqldump導(dǎo)出的SQL文件如果不帶絕對路徑,默認是保存在bin目錄下的。
–opt:此Mysqldump命令參數(shù)是可選的,如果帶上這個選項代表激活了Mysqldump命令的quick,add-drop-table,add-locks,extended-insert,lock-tables參數(shù),也就是通過–opt參數(shù)在使用Mysqldump導(dǎo)出Mysql數(shù)據(jù)庫信息時不需要再附加上述這些參數(shù)。
–quick:代表忽略緩沖輸出,Mysqldump命令直接將數(shù)據(jù)導(dǎo)出到指定的SQL文件。
–add-drop-table:顧名思義,就是在每個CREATE TABEL命令之前增加DROP-TABLE IF EXISTS語句,防止數(shù)據(jù)表重名。
–add-locks:表示在INSERT數(shù)據(jù)之前和之后鎖定和解鎖具體的數(shù)據(jù)表,你可以打開Mysqldump導(dǎo)出的SQL文件,在INSERT之前會出現(xiàn)LOCK TABLES和UNLOCK TABLES語句。
–extended-insert (-e):此參數(shù)表示可以多行插入。
更多的Mysqldump命令參數(shù)你可以通過
Mysqldump --help
命令查看Mysqldump包含的所有參數(shù)以及參數(shù)的支持情況。
Mysqldump導(dǎo)出命令實例如下
Mysql數(shù)據(jù)庫安裝后默認包含mysql數(shù)據(jù)庫,我就以此數(shù)據(jù)庫為例來演示Mysqldump的各種導(dǎo)出實例。
使用Mysqldump導(dǎo)出數(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導(dǎo)出單個表
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導(dǎo)出數(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導(dǎo)出的數(shù)據(jù)中不含有INSERT數(shù)據(jù),僅僅只是Mysql數(shù)據(jù)庫表user的結(jié)構(gòu)信息。對于這個參數(shù)你也可以使用-d來表示。
使用Mysqldump導(dǎo)出指定條件的數(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導(dǎo)出實例中,通過設(shè)定Mysqldump命令參數(shù) –where=conditions設(shè)定導(dǎo)出的INSERT數(shù)據(jù)條件為user表中user字段為root的INSERT記錄。通過這個參數(shù)你可以根據(jù)需要選用Mysqldump導(dǎo)出自己想要的數(shù)據(jù),非常方便。注意在這個where選項前后都需要使用雙引號,具體的條件可以使用單引號,否則在解析Mysqldump命令行參數(shù)時會出錯,另外你也可以指定多個where參數(shù)。
Mysql數(shù)據(jù)庫導(dǎo)入命令Source詳解
Mysql最常用的數(shù)據(jù)庫導(dǎo)入命令就是Source,Source命令的用法非常簡單,首先你需要進入Mysql數(shù)據(jù)庫的命令行管理界面,然后選擇需要導(dǎo)入的數(shù)據(jù)庫,即
USER 數(shù)據(jù)庫
source 已導(dǎo)出的SQL文件
注意需要導(dǎo)入的SQL文件的具體目錄地址,最好使用/。
至此Mysql命令行導(dǎo)出工具Mysqldump命令以及Mysql導(dǎo)入命令Source的用法就介紹完了,相對于Mysql Source命令,Mysqldump導(dǎo)出功能更豐富,合理利用Mysqldump命令參數(shù)能夠?qū)崿F(xiàn)不同的效果。
mysqldump命令導(dǎo)出數(shù)據(jù)用法詳解
在平時的mysql應(yīng)用中,總會碰到導(dǎo)入數(shù)據(jù),導(dǎo)出數(shù)據(jù),當然有很多方法,這篇文章,主要介紹應(yīng)用mysqlmysqldump命令進行數(shù)據(jù)導(dǎo)入導(dǎo)出,希望對大家有所幫助。
mysqldump命令中帶有一個 --where/-w 參數(shù),它用來設(shè)定數(shù)據(jù)導(dǎo)出的條件,使用方式和SQL查詢命令中中的where基本上相同,有了它,我們就可以從數(shù)據(jù)庫中導(dǎo)出你需要的那部分數(shù)據(jù)了。
1.命令格式如下:
mysqldump -u用戶名 -p密碼 數(shù)據(jù)庫名 表名 --where="篩選條件" > 導(dǎo)出文件路徑
例子:
從test數(shù)據(jù)庫的test_data表中導(dǎo)出id大于100的數(shù)據(jù)到 /tmp/test.sql 這個文件中
mysqldump -uroot -p123456 test test_data --where=" id > 100" > /tmp/test.sql
2.導(dǎo)出整個數(shù)據(jù)庫
mysqldump -u 用戶名 -p 數(shù)據(jù)庫名 > 導(dǎo)出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
3.導(dǎo)出一個數(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
導(dǎo)出庫表(mysqldump)條件
mysqldump -u用戶名 -p密碼 -h主機 數(shù)據(jù)庫 a -w “sql條件” –lock-all-tables > 路徑
1 mysqldump -hhostname -uusername -p dbname tbname>xxxx.sql
** 按指定條件導(dǎo)出數(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?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
