Mysql兩種儲存引擎的優缺點

來源:互聯網
上載者:User

MyISAM引擎是一種非事務性的引擎,提供高速儲存和檢索,以及全文檢索搜尋能力,適合資料倉儲等查詢頻繁的應用。MyISAM中,一個table實際儲存為三個檔案,.frm儲存表定義,.MYD儲存資料,.MYI儲存索引。  NULL值被允許在索引的列中。

InnoDB:這種類型是事務安全的.它與BDB類型具有相同的特性,它們還支援外鍵.InnoDB表格速度很快.具有比BDB還豐富的特性, 因此如果需要一個事務安全的儲存引擎,建議使用它.如果你的資料執行大量的INSERT或UPDATE,出於效能方面的考慮,應該使用InnoDB表,InnoDB 給 MySQL 提供了具有事務(commit)、復原(rollback)和崩潰修複能力(crash recovery capabilities)的事務安全(transaction-safe (ACID compliant))型表。InnoDB
提供了行鎖(locking on row level),提供與 Oracle 類型一致的不加鎖讀取(non-locking read in SELECTs)。這些特性均提高了多使用者並行作業的效能表現。在InnoDB表中不需要擴大鎖定(lock escalation),因為 InnoDB 的列鎖定(row level locks)適宜非常小的空間。InnoDB 是 MySQL 上第一個提供外鍵約束(FOREIGN KEY constraints)的表引擎。InnoDB 的設計目標是處理大容量資料庫系統,它的
CPU 利用率是其它基於磁碟的關聯式資料庫引擎所不能比的。在技術上,InnoDB 是一套放在 MySQL 背景完整資料庫系統,InnoDB 在主記憶體中建立其專用的緩衝池用於高速緩衝資料和索引。 InnoDB 把資料和索引存放在資料表空間裡,可能包含多個檔案,這與其它的不一樣,舉例來說,在 MyISAM 中,表被存放在單獨的檔案中。InnoDB 表的大小隻受限於作業系統的檔案大小,一般為 2 GB。InnoDB所有的表都儲存在同一個資料檔案 ibdata1 中(也可能是多個檔案,或者是獨立的資料表空間檔案),相對來說比較不好備份,免費的方案可以是拷貝資料檔案、備份
binlog,或者用 mysqldump。

區別:
1.InnoDB不支援FULLTEXT類型的索引。
2.InnoDB 中不儲存表的具體行數,也就是說,執行select count(*) from table時,InnoDB要掃描一遍整個表來計算有多少行,但是MyISAM只要簡單的讀出儲存好的行數即可。注意的是,當count(*)語句包含 where條件時,兩種表的操作是一樣的。
3.對於AUTO_INCREMENT類型的欄位,InnoDB中必須包含只有該欄位的索引,但是在MyISAM表中,可以和其他欄位一起建立聯合索引。
4.DELETE FROM table時,InnoDB不會重建立立表,而是一行一行的刪除。
另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖全表,例如update table set num=1 where name like “%aaa%”
可以用 show create table tablename 命令看錶的類型。
2.1 對不支援事務的表做start/commit操作沒有任何效果,在執行commit前已經提交
可以執行以下命令來切換非事務表到事務(資料不會丟失),innodb表比myisam表更安全:
alter table tablename type=innodb;

        MyISAM儲存引擎的讀鎖和寫鎖是互斥的,讀寫操作是串列的。那麼,一個進程請求某個MyISAM表的讀鎖,同時另一個進程也請求同一表的寫鎖,MySQL如何處理呢?答案是寫進程先獲得鎖。不僅如此,即使讀請求先到鎖等待隊列,寫請求後到,寫鎖也會插到讀鎖請求之前!這是因為MySQL認為寫請求一般比讀請求要重要。這也正是MyISAM表不太適合於有大量更新操作和查詢操作應用的原因,因為,大量的更新操作會造成查詢操作很難獲得讀鎖,從而可能永遠阻塞。這種情況有時可能會變得非常糟糕!myisam是有讀鎖和寫鎖(2個鎖都是表層級鎖)。

        MySQL表級鎖有兩種模式:表共用讀鎖(Table Read Lock)和表獨佔寫鎖(Table Write Lock)。什麼意思呢,就是說對MyISAM表進行讀操作時,它不會阻塞其他使用者對同一表的讀請求,但會阻塞 對同一表的寫操作;而對MyISAM表的寫操作,則會阻塞其他使用者對同一表的讀和寫操作。

        InnoDB行鎖是通過給索引項目加鎖來實現的,即只有通過索引條件檢索資料,InnoDB才使用行級鎖,否則將使用表鎖!行級鎖在每次擷取鎖和釋放鎖的操作需要消耗比表鎖更多的資源。在InnoDB兩個事務發生死結的時候,會計算出每個事務影響的行數,然後復原行數少的那個事務。當鎖定的情境中不涉及Innodb的時候,innodb是檢測不到的。只能依靠鎖定逾時來解決。

        資料庫死結例子:

兩個sesison,第一個update表t1,不要提交。第二個update表t2,不要提交。接著session1去update表t2,session2去update表t1,此時就發生死結了。


冷備份mysql和熱備份mysql:

冷備份就是直接cp所有的資料庫檔案。

熱備份:

1)myisam引擎。1、flush tables with read lock; 2、 cp......; 3、unlock tables;

作為資料庫伺服器的主機,最關鍵的就是主機的整體IO效能,包括磁碟、記憶體以及各種IO相關的板卡。

在Mysql中,使用orderby 關鍵字,排序方式有兩種:

4.1版本以前的使用的是先取出需要排序的欄位和整條記錄的指標,然後對需要排序的欄位在指定的排序區進行排序,排序之後,再根據指標去取出相應的記錄。也就是說,這種演算法需要訪問資料兩次。從4.1版本開始,採取了改進演算法。一次性將所有的合格記錄取出。這樣減少了隨機IO(之前演算法排序之後去記錄為隨機IO)。但是這種改進的方法極大的浪費了排序的時候所使用的記憶體。所以為了改進效能,query語句中盡量只取出我們需要的欄位。

myql的profile可以用來分析查詢語句的cpu和io的使用方式。

[sql] view
plaincopy

  1. set profiling=1  
  2.   
  3. select count(*) from user;  
  4.   
  5. show profiles;  
  6.   
  7. show profile for query 1;  

最基本的我們可以從中看出,緩衝對於mysql的效能影響。提高速度近30倍。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.