本篇文章給大家分享的是有關(guān)MySQL如何切換引擎,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
創(chuàng)新互聯(lián)建站服務(wù)項(xiàng)目包括盤山網(wǎng)站建設(shè)、盤山網(wǎng)站制作、盤山網(wǎng)頁制作以及盤山網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,盤山網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到盤山省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
切換引擎有以下三種方法:
方法一:Alter table
將1個(gè)表的引擎修改為另一個(gè)引擎最簡單的方法是使用Alter table語句。
下面的語句將myTable的引擎修改為InnoDB
mysql>ALTER TABLE mytable ENGINE = InnoDB;
上述語法適用于任何一個(gè)引擎,但是有以下的缺點(diǎn):
A.執(zhí)行時(shí)間上,將數(shù)據(jù)從原表復(fù)制一份到新表中,消耗系統(tǒng)的I/O能力
B.原表會(huì)加上讀鎖,繁忙表上要特別注意
C.將失去和原引擎相關(guān)的所有特性,如原表的外鍵
方法二:導(dǎo)出和導(dǎo)入
可以使用mysqldump工具將數(shù)據(jù)導(dǎo)出到文件,然后修改文件中的CREATE TABLE 語句的存儲(chǔ)引擎選擇,注意要修改表名,即使使用不同的引擎。
注意:mysql導(dǎo)出的sql語句默認(rèn)會(huì)帶有drop table,不注意這一點(diǎn)會(huì)造成數(shù)據(jù)的丟失
方法三:CREATE AND SELECT
結(jié)合第一種方法的高效和第二種方法的安全。不需要導(dǎo)出整個(gè)表的數(shù)據(jù),只需要先創(chuàng)建一個(gè)新的存儲(chǔ)引擎的表,然后利用INSERT....SELECT語法來導(dǎo)數(shù)據(jù)
mysql >CREATE TABLE innodb_table LIKE myisam_table; mysql >ALTER TABLE innodb_table Engine=InnoDB; mysql >INSERT INTO innodb_table SELECT * From myisam_table;
如果數(shù)據(jù)量很大,可以考慮分批處理
mysql> STSRT TRANSACTION mysql> INSERT INTO innodb_table SELECT * From myisam_table where id BETWEEN x and y; mysql> COMMIT;
新表是原表的全量復(fù)制。如果有必要,可以在執(zhí)行過程中對(duì)原表加鎖,保證新表和原表數(shù)據(jù)一致。
以上就是mysql如何切換引擎,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。