您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關mysql如何切換引擎,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
切換引擎有以下三種方法:
方法一:Alter table
將1個表的引擎修改為另一個引擎最簡單的方法是使用Alter table語句。
下面的語句將myTable的引擎修改為InnoDB
mysql>ALTER TABLE mytable ENGINE = InnoDB;
上述語法適用于任何一個引擎,但是有以下的缺點:
A.執行時間上,將數據從原表復制一份到新表中,消耗系統的I/O能力
B.原表會加上讀鎖,繁忙表上要特別注意
C.將失去和原引擎相關的所有特性,如原表的外鍵
方法二:導出和導入
可以使用mysqldump工具將數據導出到文件,然后修改文件中的CREATE TABLE 語句的存儲引擎選擇,注意要修改表名,即使使用不同的引擎。
注意:mysql導出的sql語句默認會帶有drop table,不注意這一點會造成數據的丟失
方法三:CREATE AND SELECT
結合第一種方法的高效和第二種方法的安全。不需要導出整個表的數據,只需要先創建一個新的存儲引擎的表,然后利用INSERT....SELECT語法來導數據
mysql >CREATE TABLE innodb_table LIKE myisam_table; mysql >ALTER TABLE innodb_table Engine=InnoDB; mysql >INSERT INTO innodb_table SELECT * From myisam_table;
如果數據量很大,可以考慮分批處理
mysql> STSRT TRANSACTION mysql> INSERT INTO innodb_table SELECT * From myisam_table where id BETWEEN x and y; mysql> COMMIT;
新表是原表的全量復制。如果有必要,可以在執行過程中對原表加鎖,保證新表和原表數據一致。
以上就是mysql如何切換引擎,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。