MySQL兩種引擎的區別

來源:互聯網
上載者:User

標籤:sql語句   fulltext   方便   使用   特性   安全   sel   blog   記憶體   

Innodb引擎

Innodb引擎提供了對資料庫ACID事務的支援,並且實現了SQL標準的四種隔離等級。該引擎還提供了行級鎖和外鍵約束,它的設計目標是處理大容量資料庫系統,它本身其實就是基於MySQL背景完整資料庫系統,MySQL運行時Innodb會在記憶體中建立緩衝池,用於緩衝資料和索引。但是該引擎不支援FULLTEXT類型的索引,而且它沒有儲存表的行數,當SELECT COUNT(*) FROM TABLE時需要掃描全表。當需要使用資料庫事務時,該引擎當然是首選。由於鎖的粒度更小,寫操作不會鎖定全表,所以在並發較高時,使用Innodb引擎會提升效率。但是使用行級鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖全表。

MyIASM引擎

MyIASM沒有提供對資料庫事務的支援,也不支援行級鎖和外鍵,因此當INSERT(插入)或UPDATE(更新)資料時即寫操作需要鎖定整個表,效率便會低一些。不過和Innodb不同,MyIASM中儲存了表的行數,於是SELECT COUNT(*) FROM TABLE時只需要直接讀取已經儲存好的值而不需要進行全表掃描。如果表的讀操作遠遠多於寫操作且不需要資料庫事務的支援,那麼MyIASM也是很好的選擇。

主要區別:

1、MyIASM是非事務安全的,而InnoDB是事務安全的

2、MyIASM鎖的粒度是表級的,而InnoDB支援行級鎖

3、MyIASM支援全文類型索引,而InnoDB不支援全文索引

4、MyIASM相對簡單,效率上要優於InnoDB,小型應用可以考慮使用MyIASM

5、MyIASM表儲存成檔案形式,跨平台使用更加方便

應用情境:1、MyIASM管理非事務表,提供高速儲存和檢索以及全文檢索搜尋能力,如果再應用中執行大量select操作,應該選擇MyIASM2、InnoDB用於交易處理,具有ACID事務支援等特性,如果在應用中執行大量insert和update操作,應該選擇InnoDB

MySQL兩種引擎的區別

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.