程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> (5)mysql常用存儲引擎

(5)mysql常用存儲引擎

編輯:MySQL綜合教程

(5)mysql常用存儲引擎


概述

??mysql5.5之前默認存儲引擎是MyISAM,5.5之後改為InnoDB。若要修改默認引擎,可以修改配置文件中的default-storage-engine。可以通過show engines來查看當前數據庫支持的引擎。使用select engine from information_schema.engines where transactions = 'yes';來查看哪些引擎支持事務。在創建表到時候通過engine=...或type=...來指定所要使用到引擎。

MyISAM

它不支持事務,也不支持外鍵,其優勢是訪問的速度快,對事務完整性沒有要求的或者以select/insert為主的應用基本上可以使用這個引擎來創建表。

每個MyISAM在磁盤上都有3個文件,其文件名都與表名相同,但擴展名是:

.frm(表定義) .MYD(MYDate:存儲數據) .MYI(MYIndex:存儲索引) .MYD文件和.MYI文件可以放置在不同的目錄中,通過 data directory 和index directory語句指定。 MyISAM類型的表可能會損壞,可以使用CHECK TABLE語句來檢查MyISAM表的健康,並用REPAIR TABLE語句修復一個損壞到MyISAM表。

MyISAM支持3種不同的存儲格式:

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

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

InnoDB

InnoDB支持事務安全,對比MyISAM引擎,InnoDB寫的效率差一些,並且會占據更多的磁盤空間。 InnoDB自動增長列可以手工插入,但是插入的值是空或者0,則實際插入的將是自動增長後的值。可以使用last_insert_id()查詢當前線程最後插入記錄使用的值。可以通過alert table *** auto_increment=n;語句強制設置自動增長值。 對於InnoDB表,自動增長列必須是索引。如果是組合索引,也必須是組合索引的第一列,但是對於MyISAM表,自動增長列可以是組合索引的其他列,這樣插入記錄後,自動增長列是按照組合索引到前面幾列排序後遞增的。 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;打開約束。

InnoDB存儲表和索引有如下兩種方式:

使用共享表空間存儲。 使用多表空間存儲。

MEMORY

memory使用存在內存中的內容來創建表。每個MEMORY表實際對應一個磁盤文件,格式是.frm。MEMORY類型的表訪問非常快,因為它到數據是放在內存中的,並且默認使用HASH索引,但是一旦服務器關閉,表中的數據就會丟失,但表還會繼續存在。 每個MEMORY表中放置到數據量的大小,受到max_heap_table_size系統變量的約束,這個系統變量的初始值是16M,同時在創建MEMORY表時可以使用MAX_ROWS子句來指定表中的最大行數。 memory主要用於那些內容變化不頻繁的代碼表,或作為統計操作的中間結果表。

MERGE

merge存儲引擎是一組MyISAM表的組合,這些MyISAM表結構必須完全相同,MERGE表中並沒有數據,對MERGE類型的表可以進行查詢、更新、刪除的操作,這些操作實際上是對內部的MyISAM表進行操作。 對於對MERGE表進行的插入操作,是根據INSERT_METHOD子句定義的插入的表,可以有3個不同的值,first和last值使得插入操作被相應的作用在第一個或最後一個表上,不定義這個子句或者為NO,表示不能對這個MERGE表進行插入操作。 可以對MERGE表進行drop操作,這個操作只是刪除MERGE表的定義,對內部的表沒有任何影響。 MERGE在磁盤上保留2個以MERGE表名開頭文件:.frm文件存儲表的定義;.MRG文件包含組合表的信息,包括MERGE表由哪些表組成,插入數據時的依據。可以通過修改.MRG文件來修改MERGE表,但是修改後要通過flush table刷新。 merge表與分區表的區別是:merge表不會智能的將記錄寫到對應的表中,而分區表可以的。

總結

仍一張表作為總結:
mysql常用存儲引擎

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved