搜尋
首頁資料庫mysql教程mysql innodb是什麼

mysql innodb是什麼

Apr 14, 2023 am 10:19 AM
mysqlinnodb

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

mysql innodb是什麼

本教學操作環境:windows7系統、mysql8版本、Dell G3電腦。

如果想看自己的資料庫預設使用的那個儲存引擎,可以透過使用指令SHOW VARIABLES LIKE 'storage_engine';

一、InnoDB儲存引擎

InnoDB,是MySQL的資料庫引擎之一,現在是MySQL的預設儲存引擎,並為MySQL AB發布binary的標準之一。 InnoDB由Innobase Oy公司所開發,2006年五月時由甲骨文公司併購。與傳統的ISAM與MyISAM相比,InnoDB的最大特色就是支援了ACID相容的事務(Transaction)功能,類似PostgreSQL。

InnoDB採用雙軌制授權,一個是GPL授權,另一個是專有軟體授權。

1、InnoDB是事務型資料庫的首選引擎,支援事務安全表(ACID)

交易的ACID屬性:即原子性、一致性、隔離性、持久性

                         要回滾到事務開始執行的地方。

                             redred#p##redpo
##redpo

##redpo#-

#redpo#-red系統的主要日誌。事務是一組SQL語句,裡面有選擇,查詢、刪除等功能。每條語句執行會有一個節點。例如,刪除語句執行後,在事務中有個記錄保存下來,這個記錄中儲存了我們什麼時候做了什麼事。如果出錯了,就會回滾到原來的位置,redo裡面已經儲存了我做過什麼事了,然後逆向執行一遍就可以了。

                              (eg:例如A向B轉賬,不可能A扣了錢,B卻沒有收到)

                   同一數據,彼此沒有任何干擾;

                    

##                              為一個事務正在多次修改某個數據,而在這個事務中這多次的修改都還未提交,這時一個並發的事務來訪問該數據,就會造成兩個事務得到的數據不一致);(讀取了另一個事務未提交的髒資料)
                     個數據,一個事務範圍內多次查詢卻返回了不同的數據值,這是由於在查詢間隔,被另一個事務修改並提交了;(讀取了前一個事務提交的數據,查詢的都是同一個資料項)

                              所產的非學習現象(非重複閱讀」的一個非重複讀寫:虛讀為獨立時所讀的行為表(11121121221212萬元:假讀)中所產生的一種獨立行為:一個獨立的動作。的某個資料項做了從「1」修改為「2」的操作,這時事務T2又對這個表中插入了一行資料項,而這個資料項的數值還是為「1」並且提交給資料庫。而操作事務T1的使用者如果再查看剛剛修改的數據,會發現還有一行沒有修改,其實這行是從事務T2中添加的,就好像產生幻覺一樣 );(讀取了前一個事務提交的數據,針對一批數據整體)##               :交易完成後,交易對資料庫的所有更新將被保存到資料庫,不能回滾

2、InnoDB是mySQL預設的儲存引擎,預設的隔離等級是RR,並且在RR的隔離等級下更近一步,透過多版本並發控制(MVCC)解決不可重複讀取問題,加上間隙鎖定(也就是並發控制)解決幻讀問題。因此InnoDB的RR隔離等級其實實現了串列化等級的效果,而保留了比較好的並發效能。

MySQL資料庫提供給我們的四個隔離等級:

a、Serializable(串列化):可避免髒讀、無法重複讀取、幻讀的發生;

b、Repeatable read(可重複讀):可避免髒讀、不可重複讀的發生;

c、Read committed(讀已提交):可避免髒讀的發生;

d、Read uncommitted(讀未提交):最低級別,任何情況都無法保證;

從a----d隔離級別由高到低,級別越高,執行效率越低

3、InnoDB支援行級鎖定。行級鎖可以最大程度的支援並發,行級鎖是由儲存引擎層實現的。

鎖定

:鎖定的主要功能是管理共享資源的並發訪問,用於實現事務的隔離性

       

類型:共享鎖定(讀鎖)、獨佔鎖定(寫入鎖定)

                

      鎖的力度:表級鎖(開銷小、並發性低),通常在服務器層實現                                    行級鎖(開銷大、並發性高) ,只會在儲存引擎層面進行實作


4、InnoDB是為處理龐大資料量的最大效能設計。它的CPU效率可能是任何基於磁碟的關係型資料庫引擎所不能匹敵的

#5、InnoDB儲存引擎完全與MySQL伺服器整合,InnoDB儲存引擎為在主記憶體中緩存數據和索引而維持它自己的緩衝池。 InnoDB將它的表和索引在一個邏輯表空間中,表空間可以包含幾個檔案(或原始磁碟檔案);

6、InnoDB支援外鍵完整性約束,儲存表中的資料時,每張表的儲存都會依照主鍵順序存放,如果沒有顯示在表定義時指定主鍵。 InnoDB會為每一行產生一個6位元組的ROWID,並以此作為主鍵

#7、InnoDB被用在眾多需要高效能的大型資料庫網站上

8、InnoDB中不保存表格的行數(eg:select count(*)from table時,InnoDB需要掃描一遍整個表來計算有多少行);清空整個表時,InnoDB是一行一行的刪除,效率非常慢;

InnoDB不建立目錄,使用InnoDB時,MySQL將在MySQL資料目錄下建立一個名為ibdata1的10MB大小的自動擴充資料文件,以及兩個名為ib_logfile0和ib_logfile1的5MB大小的日誌檔案

#二、InnoDB引擎的底層實作

InnoDB的儲存檔案有兩個,後綴名分別是 .frm和 .idb;其中 .frm是表格的定義文件, .idb是表格的資料檔案。

1、InnoDB引擎採用B Tree結構來作為索引結構

B-Tree(平衡多路尋找樹):為磁碟等外儲存裝置設計的一種平衡查找樹

系統從磁碟讀取資料到記憶體時是以磁碟區塊位基本單位的,位於同一磁碟區塊中的資料會被一次性讀取出來,而不是按需讀取。

InnoDB儲存引擎使用頁面作為資料讀取單位,頁面是其磁碟管理的最小單位,預設page大小是16k.

系統的一個磁碟區塊的儲存空間往往沒有那麼大,因此InnoDB每次申請磁碟空間時都會是若干位址連續磁碟區塊來達到頁的大小16KB。

InnoDB在把磁碟資料讀入磁碟時會以頁為基本單位,在查詢資料時,如果一個頁中的每個資料都能助於定位資料記錄的位置,這將會減少磁碟I/O的次數,提高查詢效率。

B-Tree結構的資料可以讓系統高效的找到資料所在的磁碟區塊

##B-Tree中的每個節點根據實際情況可以包含大量的關鍵字資訊和分支,例如:

mysql innodb是什麼

#每個節點佔用一個磁碟區的磁碟空間,一個節點上有兩個升序排序的關鍵字和三個指向子樹根節點的指針,指針儲存的是子節點所在磁碟塊的位址。

以根節點為例,關鍵字為17和35,P1指標指向的子樹的資料範圍小於17,P2指標指向的子樹的資料範圍為17----35,P3指標指向的子樹的資料範圍大於35;

尋找#關鍵字29的過程:

a.根據根節點找到磁碟區塊1,讀入記憶體。 【磁碟I/O操作第一次】

b.比較關鍵字29在區間(17,35),找到磁碟區塊1的指標P2;

c.根據P2指標找到磁碟區塊3,讀入記憶體。 【磁碟I/O操作第二次】

d.比較關鍵字29在區間(26,30),找到磁碟區塊3的指標P2;

e.根據P2指標找到磁碟區塊8,讀入記憶體。 【磁碟I/O操作第三次】

f.在磁碟區塊8中的關鍵字清單中找到關鍵字29.

MySQL的InnoDB儲存引擎在設計時是將根節點常駐記憶體的,因此力求達到樹的深度不超過3,也就是I/O不需要超過三次;

##分析上面的結果,發現需要三次磁碟I/O操作,和三次記憶體查找操作。由於記憶體中的關鍵字是一個有序表結構,可以利用二分法查找來提高效率;而三次磁碟I/O操作時影響整個B-Tree查找效率的決定因素。

B Tree

#B Tree是在B-Tree基礎上的最佳化,使其更適合實現外部儲存索引結構,B-Tree中每個節點中有key,也有data,而每一頁的儲存空間是有限的,如果data資料較大時將會導致每個節點(即一個頁)能存儲的key的數量很小。當儲存的資料量很大時同樣會導致B-Tree的深度較大,增大查詢時的磁碟I/O次數,進而影響查詢效率。

在B Tree中所有資料記錄節點都是按照鍵值大小順序存放在同一層的葉子節點上,而非葉子節點上只儲存key值信息,這樣可以大大增加每個節點儲存的key值數量,降低B Tree的高度;

B Tree在B-Tree的基礎上有兩點變化:

#( 1)資料為存在葉子節點中的

                                 (2)資料節點之間是有指標指向的


由於B Tree的非葉子節點只儲存鍵值訊息,假設每個磁碟區塊能儲存4個鍵值及指標訊息,則變成B Tree後其結構如下圖所示:

mysql innodb是什麼

通常在B Tree上有兩個頭指針,一個指向根節點,另一個指向關鍵字最小的葉子節點,而且所有葉子節點(即資料節點)之間都是一種鍊式環結構。

因此可以對B Tree進行兩種查找運算,一種是對於主鍵的範圍查找和分頁查找,另一種是從根節點開始,進行隨機查找。

InnoDB中的B Tree

#InnoDB是以ID為索引的資料儲存

採用InnoDB引擎的資料儲存檔案有兩個,一個定義文件,一個是資料檔案。

InnoDB透過B Tree結構對ID建立索引,然後在葉子節點中儲存記錄

mysql innodb是什麼

##若建立索引的欄位不是主鍵ID,則對該欄位建立索引,然後在葉子節點中儲存的是該記錄的主鍵,然後透過主鍵索引找到對應記錄

【相關推薦:

mysql影片教學

以上是mysql innodb是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
說明InnoDB重做日誌和撤消日誌的作用。說明InnoDB重做日誌和撤消日誌的作用。Apr 15, 2025 am 12:16 AM

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

在解釋輸出(類型,鍵,行,額外)中要查找的關鍵指標是什麼?在解釋輸出(類型,鍵,行,額外)中要查找的關鍵指標是什麼?Apr 15, 2025 am 12:15 AM

EXPLAIN命令的關鍵指標包括type、key、rows和Extra。 1)type反映查詢的訪問類型,值越高效率越高,如const優於ALL。 2)key顯示使用的索引,NULL表示無索引。 3)rows預估掃描行數,影響查詢性能。 4)Extra提供額外信息,如Usingfilesort提示需要優化。

在解釋中使用臨時狀態以及如何避免它是什麼?在解釋中使用臨時狀態以及如何避免它是什麼?Apr 15, 2025 am 12:14 AM

Usingtemporary在MySQL查詢中表示需要創建臨時表,常見於使用DISTINCT、GROUPBY或非索引列的ORDERBY。可以通過優化索引和重寫查詢避免其出現,提升查詢性能。具體來說,Usingtemporary出現在EXPLAIN輸出中時,意味著MySQL需要創建臨時表來處理查詢。這通常發生在以下情況:1)使用DISTINCT或GROUPBY時進行去重或分組;2)ORDERBY包含非索引列時進行排序;3)使用複雜的子查詢或聯接操作。優化方法包括:1)為ORDERBY和GROUPB

描述不同的SQL交易隔離級別(讀取未讀取,讀取,可重複的讀取,可序列化)及其在MySQL/InnoDB中的含義。描述不同的SQL交易隔離級別(讀取未讀取,讀取,可重複的讀取,可序列化)及其在MySQL/InnoDB中的含義。Apr 15, 2025 am 12:11 AM

MySQL/InnoDB支持四種事務隔離級別:ReadUncommitted、ReadCommitted、RepeatableRead和Serializable。 1.ReadUncommitted允許讀取未提交數據,可能導致臟讀。 2.ReadCommitted避免臟讀,但可能發生不可重複讀。 3.RepeatableRead是默認級別,避免臟讀和不可重複讀,但可能發生幻讀。 4.Serializable避免所有並發問題,但降低並發性。選擇合適的隔離級別需平衡數據一致性和性能需求。

MySQL與其他數據庫:比較選項MySQL與其他數據庫:比較選項Apr 15, 2025 am 12:08 AM

MySQL適合Web應用和內容管理系統,因其開源、高性能和易用性而受歡迎。 1)與PostgreSQL相比,MySQL在簡單查詢和高並發讀操作上表現更好。 2)相較Oracle,MySQL因開源和低成本更受中小企業青睞。 3)對比MicrosoftSQLServer,MySQL更適合跨平台應用。 4)與MongoDB不同,MySQL更適用於結構化數據和事務處理。

MySQL索引基數如何影響查詢性能?MySQL索引基數如何影響查詢性能?Apr 14, 2025 am 12:18 AM

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL:新用戶的資源和教程MySQL:新用戶的資源和教程Apr 14, 2025 am 12:16 AM

MySQL學習路徑包括基礎知識、核心概念、使用示例和優化技巧。 1)了解表、行、列、SQL查詢等基礎概念。 2)學習MySQL的定義、工作原理和優勢。 3)掌握基本CRUD操作和高級用法,如索引和存儲過程。 4)熟悉常見錯誤調試和性能優化建議,如合理使用索引和優化查詢。通過這些步驟,你將全面掌握MySQL的使用和優化。

現實世界Mysql:示例和用例現實世界Mysql:示例和用例Apr 14, 2025 am 12:15 AM

MySQL在現實世界的應用包括基礎數據庫設計和復雜查詢優化。 1)基本用法:用於存儲和管理用戶數據,如插入、查詢、更新和刪除用戶信息。 2)高級用法:處理複雜業務邏輯,如電子商務平台的訂單和庫存管理。 3)性能優化:通過合理使用索引、分區表和查詢緩存來提升性能。

See all articles

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

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

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

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具