MySQL的四種主要存儲引擎

来源:http://www.cnblogs.com/zyjj/archive/2017/07/11/7151387.html
-Advertisement-
Play Games

在資料庫中存的就是一張張有著千絲萬縷關係的表,所以表設計的好壞,將直接影響著整個資料庫。而在設計表的時候,我們都會關註一個問題,使用什麼存儲引擎。等一下,存儲引擎?什麼是存儲引擎? 什麼是存儲引擎? 關係資料庫表是用於存儲和組織信息的數據結構,可以將表理解為由行和列組成的表格,類似於Excel的電子 ...


資料庫中存的就是一張張有著千絲萬縷關係的表,所以表設計的好壞,將直接影響著整個資料庫。而在設計表的時候,我們都會關註一個問題,使用什麼存儲引擎。等一下,存儲引擎?什麼是存儲引擎?

  什麼是存儲引擎?

  關係資料庫表是用於存儲和組織信息的數據結構,可以將表理解為由行和列組成的表格,類似於Excel的電子表格的形式。有的表簡單,有的表複雜,有的表根本不用來存儲任何長期的數據,有的表讀取時非常快,但是插入數據時去很差;而我們在實際開發過程中,就可能需要各種各樣的表,不同的表,就意味著存儲不同類型的數據,數據的處理上也會存在著差異,那麼。對於MySQL來說,它提供了很多種類型的存儲引擎,我們可以根據對數據處理的需求,選擇不同的存儲引擎,從而最大限度的利用MySQL強大的功能。這篇博文將總結和分析各個引擎的特點,以及適用場合,並不會糾結於更深層次的東西。我的學習方法是先學會用,懂得怎麼用,再去知道到底是如何能用的。下麵就對MySQL支持的存儲引擎進行簡單的介紹。

MySQL的四種主要存儲引擎_資料庫_MySQL_存儲引擎_課課家教育

  MySQL5.5以後預設使用InnoDB存儲引擎,其中InnoDB和BDB提供事務安全表,其它存儲引擎都是非事務安全表。

  若要修改預設引擎,可以修改配置文件中的default-storage-engine。可以通過:showvariableslike'default_storage_engine';查看當前資料庫到預設引擎。命令:showengines和showvariableslike'have%'可以列出當前資料庫所支持到引擎。其中Value顯示為disabled的記錄表示資料庫支持此引擎,而在資料庫啟動時被禁用。在MySQL5.1以後,INFORMATION_SCHEMA資料庫中存在一個ENGINES的表,它提供的信息與showengines;語句完全一樣,可以使用下麵語句來查詢哪些存儲引擎支持事物處理:selectenginefrominformation_chema.engineswheretransactions='yes';

  可以通過engine關鍵字在創建或修改資料庫時指定所使用到引擎。

  主要存儲引擎:MyISAM、InnoDB、MEMORY和MERGE介紹:

  在創建表到時候通過engine=...或type=...來指定所要使用到引擎。showtablestatusfromDBname來查看指定表到引擎。

  (一)MyISAM

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

  每個MyISAM在磁碟上存儲成3個文件,其中文件名和表名都相同,但是擴展名分別為:

  .frm(存儲表定義)

  MYD(MYData,存儲數據)

  MYI(MYIndex,存儲索引)

  數據文件和索引文件可以放置在不同的目錄,平均分配IO,獲取更快的速度。要指定數據文件和索引文件的路徑,需要在創建表的時候通過DATADIRECTORY和INDEXDIRECTORY語句指定,文件路徑需要使用絕對路徑。

  每個MyISAM表都有一個標誌,伺服器或myisamchk程式在檢查MyISAM數據表時會對這個標誌進行設置。MyISAM表還有一個標誌用來表明該數據表在上次使用後是不是被正常的關閉了。如果伺服器以為當機或崩潰,這個標誌可以用來判斷數據表是否需要檢查和修複。如果想讓這種檢查自動進行,可以在啟動伺服器時使用--myisam-recover現象。這會讓伺服器在每次打開一個MyISAM數據表是自動檢查數據表的標誌併進行必要的修複處理。MyISAM類型的表可能會損壞,可以使用CHECKTABLE語句來檢查MyISAM表的健康,並用REPAIRTABLE語句修複一個損壞到MyISAM表。

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

  靜態(固定長度)表

  動態表

  壓縮表

  其中靜態表是預設的存儲格式。靜態表中的欄位都是非變長欄位,這樣每個記錄都是固定長度的,這種存儲方式的優點是存儲非常迅速,容易緩存,出現故障容易恢復;缺點是占用的空間通常比動態表多。靜態表在數據存儲時會根據列定義的寬度定義補足空格,但是在訪問的時候並不會得到這些空格,這些空格在返回給應用之前已經去掉。同時需要註意:在某些情況下可能需要返回欄位後的空格,而使用這種格式時後面到空格會被自動處理掉。

  動態表包含變長欄位,記錄不是固定長度的,這樣存儲的優點是占用空間較少,但是頻繁到更新刪除記錄會產生碎片,需要定期執行OPTIMIZETABLE語句或myisamchk-r命令來改善性能,並且出現故障的時候恢復相對比較困難。

  壓縮表由myisamchk工具創建,占據非常小的空間,因為每條記錄都是被單獨壓縮的,所以只有非常小的訪問開支。

  (二)InnoDB

  InnoDB是一個健壯的事務型存儲引擎,這種存儲引擎已經被很多互聯網公司使用,為用戶操作非常大的數據存儲提供了一個強大的解決方案。我的電腦上安裝的MySQL5.6.13版,InnoDB就是作為預設的存儲引擎。InnoDB還引入了行級鎖定和外鍵約束,在以下場合下,使用InnoDB是最理想的選擇:

  1.更新密集的表。InnoDB存儲引擎特別適合處理多重併發的更新請求。

  2.事務。InnoDB存儲引擎是支持事務的標準MySQL存儲引擎。

  3.自動災難恢復。與其它存儲引擎不同,InnoDB表能夠自動從災難中恢復。

  4.外鍵約束。MySQL支持外鍵的存儲引擎只有InnoDB。

  5.支持自動增加列AUTO_INCREMENT屬性。

  InnoDB存儲引擎提供了具有提交、回滾和崩潰恢復能力的事務安全。但是對比MyISAM的存儲引擎,InnoDB寫的處理效率差一些並且會占用更多的磁碟空間以保留數據和索引。

  1)自動增長列:

  InnoDB表的自動增長列可以手工插入,但是插入的如果是空或0,則實際插入到則是自動增長後到值。可以通過"ALTERTABLE...AUTO_INCREMENT=n;"語句強制設置自動增長值的起始值,預設為1,但是該強制到預設值是保存在記憶體中,資料庫重啟後該值將會丟失。可以使用LAST_INSERT_ID()查詢當前線程最後插入記錄使用的值。如果一次插入多條記錄,那麼返回的是第一條記錄使用的自動增長值。

  對於InnoDB表,自動增長列必須是索引。如果是組合索引,也必須是組合索引的第一列,但是對於MyISAM表,自動增長列可以是組合索引的其他列,這樣插入記錄後,自動增長列是按照組合索引到前面幾列排序後遞增的。

  2)外鍵約束:

  MySQL支持外鍵的存儲引擎只有InnoDB,在創建外鍵的時候,父表必須有對應的索引,子表在創建外鍵的時候也會自動創建對應的索引。

  在創建索引的時候,可以指定在刪除、更新父表時,對子表進行的相應操作,包括restrict、cascade、setnull和noaction。其中restrict和noaction相同,是指限制在子表有關聯的情況下,父表不能更新;casecade表示父表在更新或刪除時,更新或者刪除子表對應的記錄;setnull則表示父表在更新或者刪除的時候,子表對應的欄位被setnull。

  當某個表被其它表創建了外鍵參照,那麼該表對應的索引或主鍵被禁止刪除。

  可以使用setforeign_key_checks=0;臨時關閉外鍵約束,setforeign_key_checks=1;打開約束。

(二)InnoDB

  (三)MEMORY

  memory使用存在記憶體中的內容來創建表。每個MEMORY表實際對應一個磁碟文件,格式是.frm。MEMORY類型的表訪問非常快,因為它到數據是放在記憶體中的,並且預設使用HASH索引,但是一旦伺服器關閉,表中的數據就會丟失,但表還會繼續存在。

  預設情況下,memory數據表使用散列索引,利用這種索引進行“相等比較”非常快,但是對“範圍比較”的速度就慢多了。因此,散列索引值適合使用在"="和"<=>"的操作符中,不適合使用在"<"或">"操作符中,也同樣不適合用在orderby字句里。如果確實要使用"<"或">"或betwen操作符,可以使用btree索引來加快速度。

  存儲在MEMORY數據表裡的數據行使用的是長度不變的格式,因此加快處理速度,這意味著不能使用BLOB和TEXT這樣的長度可變的數據類型。VARCHAR是一種長度可變的類型,但因為它在MySQL內部當作長度固定不變的CHAR類型,所以可以使用。

  createtabletab_memoryengine=memoryselectid,name,age,addrfrommanorderbyid;

  使用USINGHASH/BTREE來指定特定到索引。

  createindexmem_hashusinghashontab_memory(city_id);

  在啟動MySQL服務的時候使用--init-file選項,把insertinto...select或loaddatainfile這樣的語句放入到這個文件中,就可以在服務啟動時從持久穩固的數據源中裝載表。

  伺服器需要足夠的記憶體來維持所在的在同一時間使用的MEMORY表,當不再使用MEMORY表時,要釋放MEMORY表所占用的記憶體,應該執行DELETEFROM或truncatetable或者刪除整個表。

  每個MEMORY表中放置到數據量的大小,受到max_heap_table_size系統變數的約束,這個系統變數的初始值是16M,同時在創建MEMORY表時可以使用MAX_ROWS子句來指定表中的最大行數。

      使用MySQL Memory存儲引擎的出發點是速度。為得到最快的響應時間,採用的邏輯存儲介質是系統記憶體。雖然在記憶體中存儲表數據確實會提供很高的性能,但當mysqld守護進程崩潰時,所有的Memory數據都會丟失。獲得速度的同時也帶來了一些缺陷。它要求存儲在Memory數據表裡的數據使用的是長度不變的格式,這意味著不能使用BLOB和TEXT這樣的長度可變的數據類型,VARCHAR是一種長度可變的類型,但因為它在MySQL內部當做長度固定不變的CHAR類型,所以可以使用。

  (四)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表,但是修改後要通過flushtable刷新。

  createtableman_all(idint,namevarchar(20))engine=mergeunion=(man1,man2)insert_methos=last;

(三)MEMORY   


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 概述 1 概述 1.1 已發佈【SqlServer系列】文章 【SqlServer系列】SQLSERVER安裝教程 【SqlServer系列】資料庫三大範式 【SqlServer系列】表單查詢 1.2 本篇文章內容概要 1.3 本篇文章內容概括 在SQL語句中,關於表連接,若按照表的數量來劃分, ...
  • MySQL配置文件 MySQL軟體使用的配置文件名為my.ini,在安裝目錄下。 MySQL常用配置參數: 1.default-character-set:客戶端預設字元集。 2.character-set-server:伺服器端預設字元集。 3.port:客戶端和伺服器端的埠號。 4.defau ...
  • 我們首先看一下自己的環境: MHA已經搭建: master:172.16.16.35:3306 slave:172.16.16.35:3307 slave:172.16.16.34:3307 MHA manager在172.16.16.34,配置文件如下: MHA manager在172.16.16 ...
  • 環境及測試 使用.net驅動npgsql連接post資料庫。配置:win10 x64, i5 4590, 16G DDR3, SSD 850EVO. postgresql 9.6.3,資料庫與數據都安裝在SSD上,預設配置,無擴展。 1. 導入 使用數據備份,csv格式導入,文件位於機械硬碟上,48 ...
  • 1.windows上下載安裝sbt 去sbt官網下載 sbt包,解壓到指定目錄,不需要安裝。記得配置環境變數。 新建 SBT_HOME ,值是sbt包的解壓路徑,比如C:\Users\***\Tools\sbt-0.13.15\sbt(建議不要放在C盤) 併在path 中添加 %SBT_HOME%\ ...
  • KMenas演算法比較簡單,不詳細介紹了,直接上代碼。 運行結果: ...
  • 在Red Hat Enterprise Linux Server release 5.7 (Tikanga)上使用RPM方式安裝Percona Xtrabackup 2.4.6時遇到了一些問題,特意總結在此。 [root@DB-Server tmp]#yum -y install perl perl... ...
  • 為什麼SqlServer有完整備份、差異備份和事務日誌備份三種備份方式,以及為什麼資料庫又有簡單模式、完整模式和大容量日誌模式這三種恢復模式。本文內容適用於2005以上所有版本的SqlServer資料庫。 單就操作過程而言,SqlServer中資料庫備份和恢復過程是相當簡單的,可以通過Managem ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...