首頁  >  文章  >  資料庫  >  MySQL中myisam轉innodb的實例教程

MySQL中myisam轉innodb的實例教程

零下一度
零下一度原創
2017-06-17 16:56:371185瀏覽

myisam轉innodb就是要修改表的儲存引擎了這個如果不按標準方法來修改myisam轉innodb那麼可能導致資料庫損壞及資料遺失問題了,下面我們來看正確的myisam轉innodb方法。

<script>ec(2);</script>

這裡簡單的介紹一下兩者間的差異和轉換方法:

MyISAM:MyISAM是MySQL5.5之前版本預設的資料庫儲存引擎。 MYISAM提供高速儲存和檢索,以及全文搜尋能力,適合資料倉儲等查詢頻繁的應用。但不支援事務、也不支援外鍵。 MyISAM格式的一個重要缺陷是無法在表損壞後恢復資料。

InnoDB:InnoDB是MySQL5.5版本的預設資料庫儲存引擎,不過InnoDB已被Oracle收購,MySQL自行開發的新儲存引擎Falcon將在MySQL6.0版引進。 InnoDB具有提交、回滾和崩潰復原能力的事務安全性。但比起MyISAM儲存引擎,InnoDB寫的處理效率差一些並且會佔用更多的磁碟空間以保留資料和索引。儘管如此,但InnoDB包括了對事務處理和外來鍵的支持,這兩點都是MyISAM引擎所沒有的。

MyISAM適合:(1)做很多count 的計算;(2)插入不頻繁,查詢非常頻繁;(3)沒有交易。
InnoDB適合:(1)可靠性要求比較高,或要求事務;(2)表更新和查詢都相當的頻繁,並且表鎖定的機會比較大的情況。 (4)效能較好的伺服器,例如單獨的資料庫伺服器,像阿里雲的關係型資料庫RDS就推薦使用InnoDB引擎。

MySQL一般提供多種儲存引擎,可以透過執行以下指令查看:

先進入MySQL命令列模式

查看MySQL提供什麼存儲引擎:
mysql> show engines;

查看MySQL目前預設的儲存引擎:
mysql> show variables like '%storage_engine%';

查詢wpsql庫
mysql>use wpsql;

列出目前庫所有表名
mysql> show tables;

你要看wp_posts表用了什麼引擎(在顯示結果裡參數engine後面的就表示該表目前用的儲存引擎):
mysql> show create table wp_posts;

將wp_posts表修為InnoDB儲存引擎(也可以此指令將InnoDB換為MyISAM):
mysql> ALTER TABLE wp_posts ENGINE=INNODB;
如果要更改整個資料庫表的儲存引擎,一般要一個表一個表的修改,比較繁瑣,可以採用先把資料庫導出,得到SQL,把MyISAM全部替換為INNODB ,再導入資料庫的方式。

轉換完畢後重啟mysql
> service mysqld restart

##

以上是MySQL中myisam轉innodb的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn