MySQL學習筆記(7):存儲引擎

来源:https://www.cnblogs.com/garvenc/archive/2020/06/30/mysql_learning_7_storage_engine.html
-Advertisement-
Play Games

本文更新於2019-06-23,使用MySQL 5.7,操作系統為Deepin 15.4。 和大多數資料庫不同,插件式存儲引擎是MySQL最重要的特性之一。 InnoDB InnoDB表提供事務安全。 InnoDB表支持外鍵。創建外鍵時,要求父表必須有對應的索引,子表在創建外鍵時也會自動創建對應的索 ...


本文更新於2019-06-23,使用MySQL 5.7,操作系統為Deepin 15.4。

目錄

和大多數資料庫不同,插件式存儲引擎是MySQL最重要的特性之一。

InnoDB

InnoDB表提供事務安全。

InnoDB表支持外鍵。創建外鍵時,要求父表必須有對應的索引,子表在創建外鍵時也會自動創建對應的索引。如父表被子表創建了外鍵索引,則父表的索引禁止被刪除。在導入多個表的數據時,或在執行LOAD DATAALTER TABLE操作的時候,可以使用SET foreign_key_checks=0關閉外鍵檢查。執行完後,使用SET foreign_key_checks=1重新打開。

InnoDB表自動增長列必需是索引,或組合索引的第一列。

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

  • 使用共用表空間存儲:表結構保存在.frm文件中,數據和索引保存在innodb_data_home_dirinnodb_data_file_path定義的表空間中,可以是多個文件。
  • 使用多表空間存儲:表結構保存在.frm文件中,每個表的數據和索引單獨保存在.ibd文件中。如果是分區表,則每個分區對應單獨的.ibd文件,文件名為“表名+分區名”,可以在創建分區的時候指定每個分區的文件位置。共用表空間仍然是必須的,InnoDB把內部數據詞典和線上重做日誌放在共用表空間中。

使用參數innodb_file_per_table可指定是否使用多表空間存儲,併在重啟伺服器後,只且只對新建的表生效。使用多表空間存儲的表,不能直接複製.frm和.ibd文件進行恢復,因為沒有共用表空間的數據字典信息。但如恢復表到原來的資料庫,可使用ALTER TABLE tablename DISCARD TABLESPACEALTER TABLE tablename IMPORT TABLESPACE

InnoDB表沒有表元數據的緩存(如行數,因而執行COUNT(*)較慢)。

MyISAM

MyISAM表不支持事務,也不支持外鍵。

MyISAM表自動增長列可為組合索引的非第一列。

每個MyISAM在磁碟上存儲成3個文件,數據文件和索引文件可以放置在不同的目錄(需在創建表時通過DATA DIRECTORYINDEX DIRECTORY指定)。其文件名和表名相同,擴展名分別是:

  • .frm:存儲表定義。
  • .MYD:MYData,存儲數據。
  • .MYI:MYIndex,存儲索引。

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

  • 靜態表:預設的存儲格式,每條記錄都是固定長度的。
  • 動態表:記錄不是固定長度的,包含變長欄位。
  • 壓縮表:由myisampack工具創建,每條記錄都被單獨壓縮。

MyISAM表有表元數據的緩存(如行數,因而執行COUNT(*)較快)。

MERGE

MERGE表是一組MyISAM表的組合,這些MyISAM表必須結構完全相同。MERGE表本身並沒有數據,對其的任何操作實際上是對內部MyISAM表進行的。可以對MERGE表進行DROP操作,其只是刪除表定義,對內部的表沒有影響。

MERGE表在磁碟中保存兩個文件,文件名以表名開始,.frm存儲表定義,.MRG包含組合表的信息,包括MERGE表由哪些表組成、插入新數據時的依據。可以通過修改.MRG文件來修改MERGE表,但修改後需使用FLUSH TABLES刷新。

MEMORY

MEMORY表的數據放在記憶體中,每個MEMORY表只對應一個.frm磁碟文件。

在啟動MySQL服務時使用--init-file選項,把INSERT INTO ... SELECTLOAD DATA INFILE寫入文件中,就可在服務啟動時從持久穩固的數據源裝載表。定義MEMORY表的時候可通過MAX_ROWS指定表的最大行數。

NDB

NDB存儲引擎在MySQL Cluster中使用。

常用存儲引擎對比

特點 InnoDB MyISAM MERGE MEMORY NDB
存儲限制 64TB 沒有
事務安全 支持
鎖機制 行鎖 表鎖 表鎖 表鎖 行鎖
B樹索引 支持 支持 支持 支持 支持
哈希索引 支持 支持
全文索引 支持
集群索引 支持
數據緩存 支持 支持 支持
索引緩存 支持 支持 支持 支持 支持
數據可壓縮 支持
空間使用 N/A
記憶體使用 中等
批量插入速度
支持外鍵 支持

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

-Advertisement-
Play Games
更多相關文章
  • 今天要給大家介紹的一個 Unix 下的一個 網路數據採集分析工具,也就是我們常說的抓包工具。 與它功能類似的工具有 wireshark ,不同的是,wireshark 有圖形化界面,而 tcpdump 則只有命令行。 由於我本人更習慣使用命令行的方式進行抓包,因此今天先跳過 wireshark,直接 ...
  • 操作資料庫 語句分類 DDL 定義庫、表 create 、drop、alter DML 更新數據 insert 、update、delete DQL 查詢 select DCL 控制 grant、deny、revoke TCL 事務 commit、rollback DDL示例 創建資料庫 : cre ...
  • ## 初始MySQL 為什麼要學習資料庫? 崗位技能需求 存儲數據的方法 程式、網站中,需要長久保存大量數據 資料庫是幾乎軟體體系中最核心的一個存在 什麼是資料庫? 資料庫(Database)是:按照數據結構來組織、存儲和管理數據的倉庫。 資料庫總覽 關係型資料庫(SQL) MySQL、Oracl ...
  • 1、MongoDB簡介 1.1、什麼是MongoDB MongoDB 是一個跨平臺的,面向文檔的資料庫,是當前 NoSQL 資料庫產品中最熱 門的一種。它介於關係資料庫和非關係資料庫之間,是非關係資料庫當中功能最豐富,最 像關係資料庫的產品。它支持的數據結構非常鬆散,是類似 JSON 的 BSON ...
  • 項目響應速度要求比較高,全部使用Redis緩存這也導致緩存。需要分析各種鍵占用記憶體情況進行優化。 redisclient雖然可以很方便的對redis進行操作,但不能查看對應key占用的記憶體情況,也無法對占用記憶體的key進行統計分析。我簡單的瞭解一下市面上的可以查看redis中的key的占用的開源中間 ...
  • 在sparkSQL 中將計算結果保存為視圖,關聯其他表後出現結果匹配錯誤,通過分析發現,是因為sql語句中使用了表達式 row_number() over(order by 1) 其實該表達式並沒有執行,真正執行的時候是需要觸發action (例如 show, count, top .......) ...
  • 序 平時在Oracle的日常相關開發這種,總會遇到各種各樣的坑,索性在這裡記錄下,後續慢慢更新 如有問題,望指正,不勝感激! 1、Oracle 12c登錄問題 背景:之前一直在 Oracle 11g 資料庫上進行相關開發,最近新進項目組使用的是 Oracle 12c 遂入坑12c,瞭解一下新特性 問 ...
  • Redis的發佈與訂閱,有點類似於消息隊列,發送者往頻道發送消息,頻道的訂閱者接收消息。 1. 發佈與訂閱示例 首先,在本機開啟第1個Redis客戶端,執行如下命令訂閱blog.redis頻道: SUBSCRIBE "blog.redis" 然後,在本機開啟第2個Redis客戶端,執行相同的命令訂閱 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...