溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mysql如何切換引擎

發(fā)布時(shí)間:2020-09-23 10:17:47 來源:億速云 閱讀:287 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關(guān)mysql如何切換引擎,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(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í)行過程中對原表加鎖,保證新表和原表數(shù)據(jù)一致。

以上就是mysql如何切換引擎,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI