本篇文章給大家分享的是有關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如何切換引擎,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創新互聯行業資訊頻道。
新聞標題:mysql如何切換引擎
分享URL:http://vcdvsql.cn/article4/gdgeie.html
成都網站建設公司_創新互聯,為您提供標簽優化、外貿建站、關鍵詞優化、電子商務、小程序開發、App設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯