(5)mysql常用儲存引擎

來源:互聯網
上載者:User

標籤:mysql   儲存引擎   innodb   myisam   

概述

??mysql5.5之前預設儲存引擎是MyISAM,5.5之後改為InnoDB。若要修改預設引擎,可以修改設定檔中的default-storage-engine。可以通過show engines來查看當前資料庫支援的引擎。使用select engine from information_schema.engines where transactions = ‘yes‘;來查看哪些引擎支援事務。在建立表到時候通過engine=...或type=...來指定所要使用到引擎。

MyISAM
  1. 它不支援事務,也不支援外鍵,其優勢是訪問的速度快,對事務完整性沒有要求的或者以select/insert為主的應用基本上可以使用這個引擎來建立表。
  2. 每個MyISAM在磁碟上都有3個檔案,其檔案名稱都與表名相同,但副檔名是:

    • .frm(表定義)
    • .MYD(MYDate:儲存資料)
    • .MYI(MYIndex:儲存索引)
  3. .MYD檔案和.MYI檔案可以放置在不同的目錄中,通過 data directory 和index directory語句指定。
  4. MyISAM類型的表可能會損壞,可以使用CHECK TABLE語句來檢查MyISAM表的健康,並用REPAIR TABLE語句修複一個損壞到MyISAM表。
  5. MyISAM支援3種不同的儲存格式:

    • 靜態(固定長度)表
    • 動態表
    • 壓縮表

    ??在靜態表中,如果需要儲存的內容後面本來就帶有空格,那麼在返回結果的時候會去掉公用的。
    ??在動態表中,記錄不固定,優點是佔用空間相對比較少,缺點是頻繁的更新和刪除記錄會產生片段,需要定期執行optimize table 來改善效能。
    ??在壓縮表中,由myisampack工具建立,佔據非常小的磁碟空間。因為每個記錄都被單獨壓縮的。

InnoDB
  1. InnoDB支援事務安全,對比MyISAM引擎,InnoDB寫的效率差一些,並且會佔據更多的磁碟空間。
  2. InnoDB自動成長列可以手工插入,但是插入的值是空或者0,則實際插入的將是自動成長後的值。可以使用last_insert_id()查詢當前線程最後插入記錄使用的值。可以通過alert table *** auto_increment=n;語句強制設定自動成長值。
  3. 對於InnoDB表,自動成長列必須是索引。如果是複合式索引,也必須是複合式索引的第一列,但是對於MyISAM表,自動成長列可以是複合式索引的其他列,這樣插入記錄後,自動成長列是按照複合式索引到前面幾列排序後遞增的。
  4. MySQL支援外鍵的儲存引擎只有InnoDB,在建立外鍵的時候,父表必須有對應的索引,子表在建立外鍵的時候也會自動建立對應的索引。在建立索引的時候,可以指定在刪除、更新父表時,對子表進行的相應操作,包括restrict、cascade、set null和no action。其中restrict和no action相同,是指限制在子表有關聯的情況下,父表不能更新;casecade表示父表在更新或刪除時,更新或者刪除子表對應的記錄;set null 則表示父表在更新或者刪除的時候,子表對應的欄位被set null。當某個表被其它表建立了外鍵參照,那麼該表對應的索引或主鍵被禁止刪除。可以使用set foreign_key_checks=0;臨時關閉外鍵約束,set foreign_key_checks=1;開啟約束。
  5. InnoDB儲存表和索引有如下兩種方式:

    • 使用共用資料表空間儲存。
    • 使用多資料表空間儲存。
MEMORY
  1. memory使用存在記憶體中的內容來建立表。每個MEMORY表實際對應一個磁碟檔案,格式是.frm。MEMORY類型的表訪問非常快,因為它到資料是放在記憶體中的,並且預設使用HASH索引,但是一旦伺服器關閉,表中的資料就會丟失,但表還會繼續存在。
  2. 每個MEMORY表中放置到資料量的大小,受到max_heap_table_size系統變數的約束,這個系統變數的初始值是16M,同時在建立MEMORY表時可以使用MAX_ROWS子句來指定表中的最大行數。
  3. memory主要用於那些內容變化不頻繁的代碼錶,或作為統計操作的中間結果表。
MERGE
  1. merge儲存引擎是一組MyISAM表的組合,這些MyISAM表結構必須完全相同,MERGE表中並沒有資料,對MERGE類型的表可以進行查詢、更新、刪除的操作,這些操作實際上是對內部的MyISAM表進行操作。
  2. 對於對MERGE表進行的插入操作,是根據INSERT_METHOD子句定義的插入的表,可以有3個不同的值,first和last值使得插入操作被相應的作用在第一個或最後一個表上,不定義這個子句或者為NO,表示不能對這個MERGE表進行插入操作。
  3. 可以對MERGE表進行drop操作,這個操作只是刪除MERGE表的定義,對內部的表沒有任何影響。
  4. MERGE在磁碟上保留2個以MERGE表名開標頭檔:.frm檔案儲存體表的定義;.MRG檔案包含組合表的資訊,包括MERGE表由哪些表組成,插入資料時的依據。可以通過修改.MRG檔案來修改MERGE表,但是修改後要通過flush table重新整理。
  5. merge表與分區表的區別是:merge表不會智能的將記錄寫到對應的表中,而分區表可以的。
總結

仍一張表作為總結:

(5)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.