mysql5.5之前預設儲存引擎是myisam,5.5之後改為innodb。若要修改預設引擎,可以修改配置檔案中的default-storage-engine
。可以通過show engines
來檢視當前資料庫支援的引擎。使用select engine from information_schema.engines where transactions = 'yes';
來檢視哪些引擎支援事務。在建立表到時候通過engine=...或type=...
來指定所要使用到引擎。
它不支援事務,也不支援外來鍵,其優勢是訪問的速度快,對事務完整性沒有要求的或者以select/insert為主的應用基本上可以使用這個引擎來建立表。
每個myisam在磁碟上都有3個檔案,其檔名都與表名相同,但副檔名是:
.myd檔案和.myi檔案可以放置在不同的目錄中,通過 data directory 和index directory語句指定。
myisam型別的表可能會損壞,可以使用check table語句來檢查myisam表的健康,並用repair table語句修復乙個損壞到myisam表。
myisam支援3種不同的儲存格式:
在靜態表中,如果需要儲存的內容後面本來就帶有空格,那麼在返回結果的時候會去掉公共的。
在動態表中,記錄不固定,優點是占用空間相對比較少,缺點是頻繁的更新和刪除記錄會產生碎片,需要定期執行optimize table 來改善效能。
在壓縮表中,由myisampack工具建立,佔據非常小的磁碟空間。因為每個記錄都被單獨壓縮的。
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表實際對應乙個磁碟檔案,格式是.frm。memory型別的表訪問非常快,因為它到資料是放在記憶體中的,並且預設使用hash索引,但是一旦伺服器關閉,表中的資料就會丟失,但表還會繼續存在。
每個memory表中放置到資料量的大小,受到max_heap_table_size系統變數的約束,這個系統變數的初始值是16m,同時在建立memory表時可以使用max_rows子句來指定表中的最大行數。
memory主要用於那些內容變化不頻繁的**表,或作為統計操作的中間結果表。
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常用儲存引擎
MySQL 學習筆記(5)MySQL常用函式彙總
mysql 學習筆記 5 2016 04 11 字元函式 在這些字元函式中,like not like是比較特殊的,他們需要結合資料表使用。比如 select from tb1 where col1 like m 其中 代表任意個字元 代表任意乙個字元,上面的 表示包含m的字元就都需要提取出來。常用...
MYSQL常用儲存引擎
一 innodb 儲存引擎 innodb 儲存引擎自 mysql 5.5 版本起被指定為預設的儲存引擎,用於完成事務 回滾 崩潰修復和多版本併發控制的事務安全處理。同時也是 mysql中第乙個提供外來鍵約束的表引擎,尤其對事務處理的能力,是 mysql 其他儲存引擎所無法與之比擬的。innodb 的...
常用Mysql儲存引擎
innodb是事務型資料庫的首選引擎,支援事物安全表 acid 支援行鎖定和外來鍵。mysql5.5.5之後,innodb作為預設引擎。innodb主要特性 1.innodb給mysql提供 回滾和崩潰恢復能力的事物安全 acid相容 儲存引擎。innodb鎖定在行級並且也在select語句中提供乙...