mysql儲存引擎差異有哪些
MySQL中儲存引擎的區別:以Innodb和myisam為例,前者支援事務而後者不支援;前者強調多功能性,支援的拓展功能比較多,後者主要專注於效能;前者不支援全文索引,而後者支援全文索引等
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 中,主鍵索引和資料是一體的,沒有分開。
這種實作方式,給予了 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)】是分離的,索引檔案只儲存記錄所在頁的指標(實體位置),透過這些位址來讀取頁,進而讀取被索引的行。先來看看結構圖
上圖很好地說明了樹中葉子保存的是對應行的物理位置。透過這個值,儲存引擎能順利地進行回表查詢,得到一行完整記錄。同時,每個葉子頁也保存了指向下一個葉子頁的指標。從而方便葉子節點的範圍遍歷。而對於二級索引,在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中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

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

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

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

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

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

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

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

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