不懂数据库索引原理?因为你心里没有一点B树
什么是B樹?
B樹是一種數(shù)據(jù)結(jié)構(gòu)它按排序順序在其節(jié)點中存儲數(shù)據(jù),B樹存儲數(shù)據(jù)使得每個節(jié)點按升序包含密鑰,這些鍵中的每一個都有兩個對另外兩個子節(jié)點的引用,Te左側(cè)子節(jié)點鍵小于當(dāng)前鍵右側(cè)子節(jié)點鍵多于當(dāng)前鍵,如果單個節(jié)點具有n個鍵則它可以具有最大n+1個子節(jié)點。
為什么索引在數(shù)據(jù)庫中使用?
想象一下您需要在文件中存儲數(shù)字列表并搜索該列表上的給定數(shù)字,最簡單的解決方案是將數(shù)據(jù)存儲在數(shù)組中并在新值到來時附加值,但是如果需要檢查數(shù)組中是否存在給定值則需要逐個搜索所有數(shù)組元素并檢查給定值是否存在,如果你足夠幸運你可以在第一個元素中找到給定的值,在最壞的情況下該值可以是數(shù)組中的最后一個元素,我們可以將這種最壞的情況表示為漸進符號中的O(n),這意味著如果您的數(shù)組大小最多為n則需要執(zhí)行n次搜索才能在數(shù)組中查找給定值。
你怎么能改善這個時間?最簡單的解決方案是對數(shù)組進行排序并使用二進制搜索來查找值,每當(dāng)您向數(shù)組中插入一個值時它應(yīng)該保持順序,通過從數(shù)組中間選擇一個值來搜索然后將所選值與搜索值進行比較,如果所選值大于搜索值則忽略數(shù)組的左側(cè)并搜索右側(cè)的值反之亦然。
如何在數(shù)據(jù)庫中使用索引?
當(dāng)B-tree進入數(shù)據(jù)庫索引時這個數(shù)據(jù)結(jié)構(gòu)變得有點復(fù)雜,不僅有一個鍵還有一個與鍵相關(guān)的值,該值是對實際數(shù)據(jù)記錄的引用,密鑰和值一起稱為有效負載。
結(jié)論
數(shù)據(jù)庫應(yīng)該有一種有效的方式來存儲讀取和修改數(shù)據(jù),B樹提供了插入和讀取數(shù)據(jù)的有效方法,在實際的數(shù)據(jù)庫實現(xiàn)中數(shù)據(jù)庫同時使用B樹和B+樹來存儲數(shù)據(jù),用于索引的B樹和用于存儲實際記錄的B+樹,除了二進制搜索之外B+樹還提供順序搜索功能,這使數(shù)據(jù)庫能夠更好地控制數(shù)據(jù)庫中的非索引值。
數(shù)據(jù)庫調(diào)優(yōu)集訓(xùn)課
為了讓大家更快的了解和熟悉數(shù)據(jù)庫調(diào)優(yōu),給大家推薦一門高級架構(gòu)師Zilor的在線直播課程~Zilor老師擁有12年軟件開發(fā)經(jīng)驗,7年大型互聯(lián)網(wǎng)架構(gòu)經(jīng)驗。
掃碼進集訓(xùn)學(xué)習(xí)群
7月14日~16日,Zilor老師將帶領(lǐng)大家復(fù)盤數(shù)據(jù)庫調(diào)優(yōu)的經(jīng)典場景,從原理到實戰(zhàn),干貨滿滿,讓大家快速掌握數(shù)據(jù)庫調(diào)優(yōu)的技巧。
集訓(xùn)課課程目錄
聽課送福利
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎總結(jié)
以上是生活随笔為你收集整理的不懂数据库索引原理?因为你心里没有一点B树的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C#中你想象的Task,很简单?
- 下一篇: 5分钟快速接入钉钉实现钉钉考勤