您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)C#怎么實(shí)現(xiàn)MySQL命令行備份和恢復(fù)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
MySQL數(shù)據(jù)庫的備份有很多工具可以使用,這兩天寫了一個使用C#調(diào)用MYSQL的mysqldump命令完成MySQL數(shù)據(jù)庫的備份與恢復(fù)的小工具
先來說一下mysqldump命令備份MySQL數(shù)據(jù)庫的使用方法
mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql
直接將MySQL數(shù)據(jù)庫壓縮備份
mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz
備份MySQL數(shù)據(jù)庫某個(些)表
mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql
同時備份多個MySQL數(shù)據(jù)庫
mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql
僅僅備份數(shù)據(jù)庫結(jié)構(gòu)
mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql
備份服務(wù)器上所有數(shù)據(jù)庫
mysqldump –all-databases > allbackupfile.sql
還原MySQL數(shù)據(jù)庫的命令
mysql -hhostname -uusername -ppassword databasename < backupfile.sql
還原壓縮的MySQL數(shù)據(jù)庫
gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
將數(shù)據(jù)庫轉(zhuǎn)移到新服務(wù)器
mysqldump -uusername -ppassword databasename | mysql –host=*.*.*.* -C databasename
使用C#操作MYSQL備份與恢復(fù),主要是利用C#執(zhí)行外部程序來實(shí)現(xiàn)
下面是部分C#源碼
/// <summary> /// 備份數(shù)據(jù)庫到特定目錄 /// </summary> /// <param name="binfolderpath">Bin文件夾目錄,用于得到mysqldump.exe文件</param> /// <param name="server">服務(wù)器</param> /// <param name="user">用戶名</param> /// <param name="pass">密碼</param> /// <param name="db">要備份的數(shù)據(jù)庫名</param> /// <param name="backupfile">備份到什么文件</param> /// <returns></returns> public static bool BackupDB(string binfolderpath, string server, string character, string user, string pass, string db, string backupfile) { string command = string.Format("mysqldump.exe --quick --host=\"{0}\" --default-character-set=\"{1}\" --lock-tables --verbose --force --port=3306 --user=\"{2}\" --password=\"{3}\" \"{4}\" -r \"{5}\"",server, character.Trim().ToLower(), user, pass, db, backupfile); StartCmd(binfolderpath + @"\", command); if (File.Exists(backupfile)) { return true; } else { return false; } } /// <summary> /// 恢復(fù)指定數(shù)據(jù)庫到指定文件 /// </summary> /// <param name="binfolderpath">Bin文件夾目錄,用于得到mysqldump.exe文件</param> /// <param name="server">服務(wù)器</param> /// <param name="user">用戶名</param> /// <param name="pass">密碼</param> /// <param name="db">要備份的數(shù)據(jù)庫名</param> /// <param name="backupfile">要恢復(fù)的SQL文件</param> /// <returns></returns> public static bool RestoreDB(string binfolderpath, string character, string server, string user, string pass, string db, string restorefile) { string command = string.Format("mysql.exe --host=\"{0}\" --default-character-set=\"{1}\" --port=3306 --user=\"{2}\" --password=\"{3}\" \"{4}\"<\"{5}\"", server, character.Trim().ToLower(), user, pass, db, restorefile); StartCmd(binfolderpath + @"\", command); return true; }
C#是一個簡單、通用、面向?qū)ο蟮木幊陶Z言,它由微軟Microsoft開發(fā),繼承了C和C++強(qiáng)大功能,并且去掉了一些它們的復(fù)雜特性,C#綜合了VB簡單的可視化操作和C++的高運(yùn)行效率,以其強(qiáng)大的操作能力、優(yōu)雅的語法風(fēng)格、創(chuàng)新的語言特性和便捷的面向組件編程從而成為.NET開發(fā)的首選語言,但它不適用于編寫時間急迫或性能非常高的代碼,因?yàn)镃#缺乏性能極高的應(yīng)用程序所需要的關(guān)鍵功能。
感謝各位的閱讀!關(guān)于“C#怎么實(shí)現(xiàn)MySQL命令行備份和恢復(fù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。