首頁 資料庫 mysql教程 mysql儲存引擎差異有哪些

mysql儲存引擎差異有哪些

May 06, 2019 am 11:33 AM
innodb myisam

MySQL中儲存引擎的區別:以Innodb和myisam為例,前者支援事務而後者不支援;前者強調多功能性,支援的拓展功能比較多,後者主要專注於效能;前者不支援全文索引,而後者支援全文索引等

mysql儲存引擎差異有哪些

mysql支援儲存引擎有好幾種,咱們這裡主要討論一下常用的幾種儲存引擎。 Innodb,myisam

INNODB

INNODB索引實作

與MyISAM相同的一點是,InnoDB 也採用B Tree這種資料結構來實作B-Tree索引。而很大的區別在於,InnoDB 儲存引擎採用“聚集索引”的資料儲存方式實現B-Tree索引,所謂“聚集”,就是指資料行和相鄰的鍵值緊湊地儲存在一起,注意InnoDB 只能聚集一個葉子頁(16K)的記錄(即聚集索引滿足一定的範圍的記錄),因此包含相鄰鍵值的記錄可能會相距甚遠。

在InnoDB 中,表被稱為索引組織表(index organized table),InnoDB 依照主鍵建構一顆B Tree (如果沒有主鍵,則會選擇一個唯一的且非空索引替代,如果沒有這樣的索引,InnoDB則會隱式地定義一個主鍵來作為聚集索引),同時葉子頁中存放整張表的行記錄數據,也可以將聚集索引的葉子節點稱為數據頁,非葉子頁可以看做是葉子頁的稀疏索引。

下圖說明了 InnoDB聚集索引的實作方式,同時也體現了一個 innoDB表的結構,可以看到,InnoDB 中,主鍵索引和資料是一體的,沒有分開。

mysql儲存引擎差異有哪些

這種實作方式,給予了 InnoDB 按主鍵檢索的超高效能。可以有目的性地選擇聚集索引,例如一個郵件表,可以選擇用戶ID來聚集數據,這樣只需要從磁碟讀取較少並且連續的數據頁就能獲得某個id的用戶全部的郵件,避免了讀取分散頁時所耗費的隨機I/O。

InnoDB 是 I/O 操作,Innodb讀寫採用MVCC來支援高並發。

全表掃描

當InnoDB做全表掃描時並不高效,因為InnoDB 實際上並沒有順序讀取,在大多情況下是在隨機讀取取。做全表掃描時,InnoDB 會依主鍵順序掃描頁面和行。這應用於所有的InnoDB 表,包括碎片化的表。如果主鍵頁表沒有碎片(儲存主鍵和行的頁表),全表掃描是相當快,因為讀取順序接近實體儲存順序。但是當主頁有碎片時,該掃描就會變得十分緩慢

行級鎖定

#提供行鎖(locking on row level),提供與Oracle類型一致的不加鎖讀取(non-locking read in SELECTs),另外,InnoDB表的行鎖也不是絕對的,如果在執行一個SQL語句時MySQL不能確定要掃描的範圍,InnoDB表同樣會鎖全表,例如

update table set num=1 where name like “%aaa%”
登入後複製

MYISAM

MyISAM索引的實作

每個MyISAM在磁碟上儲存成三個文件。第一個檔案的名字以表格的名字開始,副檔名指出檔案類型。 MyISAM索引檔案【.MYI (MYIndex)】和資料檔案【.MYD (MYData)】是分離的,索引檔案只儲存記錄所在頁的指標(實體位置),透過這些位址來讀取頁,進而讀取被索引的行。先來看看結構圖 

mysql儲存引擎差異有哪些

上圖很好地說明了樹中葉子保存的是對應行的物理位置。透過這個值,儲存引擎能順利地進行回表查詢,得到一行完整記錄。同時,每個葉子頁也保存了指向下一個葉子頁的指標。從而方便葉子節點的範圍遍歷。而對於二級索引,在MyISAM儲存引擎中以與上圖同樣的方式實現,這也說明了MyISAM的索引方式是“非聚集的”,與Innodb的“聚集索引”形成了對比

#MyISAM 預設會把索引讀入內存,直接在內存中操作;

表級鎖定

##小結:Innodb強調多功能性,支援的拓展功能比較多,myisam主要專注於效能

區別

1、InnoDB支援事務,MyISAM不支持,對於InnoDB每一條SQL語言都預設封裝成事務,自動提交,這樣會影響速度,所以最好把多條SQL語言放在begin和commit之間,組成一個事務;

#2、InnoDB是聚集索引,資料檔是和索引綁在一起的,必須要有主鍵,透過主鍵索引效率很高。但是輔助索引需要兩次查詢,先查詢到主鍵,再透過主鍵查詢到資料。因此,主鍵不應該太大,因為主鍵太大,其他索引也會很大。而MyISAM是非聚集索引,資料檔案是分離的,索引保存的是資料檔案的指標。主鍵索引和輔助索引是獨立的。

3、InnoDB不儲存表格的具體行數,執行select count(*) from table時需要全表掃描。而MyISAM用一個變數保存了整個表的行數,執行上述語句時只需要讀出該變數即可,速度很快;

4、Innodb不支援全文索引,而MyISAM支援全文索引,查詢效率上MyISAM要高;

以上是mysql儲存引擎差異有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

mysql innodb是什麼 mysql innodb是什麼 Apr 14, 2023 am 10:19 AM

InnoDB是MySQL的資料庫引擎之一,現在是MySQL的預設儲存引擎,為MySQL AB發布binary的標準之一;InnoDB採用雙軌制授權,一個是GPL授權,另一個是專有軟體授權。 InnoDB是事務型資料庫的首選引擎,支援事務安全表(ACID);InnoDB支援行級鎖,行級鎖可以最大程度的支援並發,行級鎖是由儲存引擎層實現的。

MySQL如何從二進位內容看InnoDB行格式 MySQL如何從二進位內容看InnoDB行格式 Jun 03, 2023 am 09:55 AM

InnoDB是將表中的資料儲存到磁碟上的儲存引擎,所以即使關機後重新啟動我們的資料還是存在的。而真正處理資料的過程是發生在記憶體中的,所以需要把磁碟中的資料載入到記憶體中,如果是處理寫入或修改請求的話,還需要把記憶體中的內容刷新到磁碟上。而我們知道讀寫磁碟的速度非常慢,和記憶體讀寫差了幾個數量級,所以當我們想從表中獲取某些記錄時,InnoDB儲存引擎需要一條一條的把記錄從磁碟上讀出來麼? InnoDB採取的方式是:將資料分割成若干個頁,以頁作為磁碟和記憶體之間互動的基本單位,InnoDB中頁的大小一般為16

mysql innodb異常怎麼處理 mysql innodb異常怎麼處理 Apr 17, 2023 pm 09:01 PM

一、回退重新裝mysql為避免再從其他地方導入這個資料的麻煩,先對目前庫的資料庫檔案做了個備份(/var/lib/mysql/位置)。接下來將Perconaserver5.7包進行了卸載,重新安裝原先老的5.1.71的包,啟動mysql服務,提示Unknown/unsupportedtabletype:innodb,無法正常啟動。 11050912:04:27InnoDB:Initializingbufferpool,size=384.0M11050912:04:27InnoDB:Complete

Mysql中的innoDB怎麼解決幻讀 Mysql中的innoDB怎麼解決幻讀 May 27, 2023 pm 03:34 PM

1.Mysql的事務隔離級別這四種隔離級別,當存在多個事務並發衝突的時候,可能會出現髒讀,不可重複讀,幻讀的一些問題,而innoDB在可重複讀隔離級別模式下解決了幻讀的一個問題,2.什麼是幻讀幻讀是指在同一個事務中,前後兩次查詢相同範圍的時候得到的結果不一致如圖,第一個事務裡面,我們執行一個範圍查詢,這時候滿足條件的資料只有一條,而在第二個事務裡面,它插入一行資料並且進行了提交,接著第一個事務再去查詢的時候,得到的結果比第一次查詢的結果多出來一條數據,注意第一個事務的第一次和第二次查詢,都在同

MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估 MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估 Jul 26, 2023 am 11:25 AM

MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估引言:在MySQL資料庫中,儲存引擎的選擇對於系統效能和資料完整性起著至關重要的作用。 MySQL提供了多種儲存引擎,其中最常用的引擎包括InnoDB、MyISAM和Memory。本文將就這三種儲存引擎進行效能指標評估,並透過程式碼範例進行比較。一、InnoDB引擎InnoDB是My

說明InnoDB全文搜索功能。 說明InnoDB全文搜索功能。 Apr 02, 2025 pm 06:09 PM

InnoDB的全文搜索功能非常强大,能够显著提高数据库查询效率和处理大量文本数据的能力。1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

如何使用MyISAM和InnoDB儲存引擎來優化MySQL效能 如何使用MyISAM和InnoDB儲存引擎來優化MySQL效能 May 11, 2023 pm 06:51 PM

MySQL是一款廣泛使用的資料庫管理系統,不同的儲存引擎對資料庫效能有不同的影響。 MyISAM和InnoDB是MySQL中最常用的兩種儲存引擎,它們的特性各有不同,使用不當可能會影響資料庫的效能。本文將介紹如何使用這兩種儲存引擎來最佳化MySQL效能。一、MyISAM儲存引擎MyISAM是MySQL最常使用的儲存引擎,它的優點是速度快,儲存佔用空間小。 MyISA

提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析 提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析 Jul 26, 2023 am 10:01 AM

提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析引言:MySQL是最常用的開源關係型資料庫管理系統之一,主要用於儲存和管理大量結構化資料。在應用中,對於資料庫的讀取效能往往是非常重要的,因為讀取操作是大部分應用的主要操作類型。本文將聚焦在如何提升MySQL儲存引擎的讀取效能,並著重分析MyISAM和InnoDB這兩個常用的存

See all articles