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
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...