青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網

17站長網 首頁 數據庫 Mysql 查看內容

MYSQL INNODB 怎樣計算B+樹表的最大容量和行數

2023-3-16 14:16| 查看: 2100 |來源: 互聯網

考慮表結構如下: create table testzh(id int primary key auto_increment ,id2 int,id3 int);插入數據:delimiter //create procedure ins3()begindeclare i ...
考慮表結構如下:
     create table testzh(id int  primary key auto_increment ,id2 int,id3 int);
插入數據:
delimiter //
 create procedure ins3()
     begin
    declare i int;
     set i=0;
     while i<10000 do
         insert into testzh(id2,id3) values(FLOOR((RAND()*100000)),FLOOR((RAND()*100000)));
         set i=i+1;
     end while;
  end;
//
delimiter ;
 
 
     這里僅僅考慮聚合索引的B+數結構。
     首先我們要考慮2個因素:
1、分支節點如何存儲一行數據
2、葉子結點如何存儲一行數據
 
位了找到這個問題我們必須要找到哪些塊是葉子結點,哪些塊是非葉子結點,這里使用自己寫的一個程序
找到詳細參考最后的代碼
(http://blog.itpub.net/7728585/viewspace-2128817/)
[root@testmy test]# ./t1  testzh.ibd
file size is 442368
Block id is 3:Index page no is 552 : B+ Tree Level is 1
Block id is 4:Index page no is 552 : B+ Tree Level is 0
Block id is 5:Index page no is 552 : B+ Tree Level is 0
Block id is 6:Index page no is 552 : B+ Tree Level is 0
Block id is 7:Index page no is 552 : B+ Tree Level is 0
Block id is 8:Index page no is 552 : B+ Tree Level is 0
Block id is 9:Index page no is 552 : B+ Tree Level is 0
.....
 
可以看到在這個文件中block_id = 3的是非葉子結點
其他的塊是葉子結點。
那我們來研究第一個問題
1、分支節點如何存儲一行數據
其實這個問題答案就是
6字節固定開銷+4字節(int數據類型4字節)+4字節(指向葉子結點的指針開銷)
我們知道每個數據庫塊的前120直接是管理固定開銷如:
FILE HEADER,INDEX HEADER等
在塊尾部也有8字節的固定開銷
那么我們從offset 120開始向后面數14個字節,這里也要使用我自己寫的工具
bcview 方便查看
./bcview testzh.ibd 16 120 14
current block:00000003--Offset:00120--cnt bytes:14--data is:00100011000e8000000100000004
得到數據:
00100011000e8000000100000004
分析一下:
00100011000e8000000100000004
 
固定開銷(6字節)
00    nullable field bitmap (?)
10    info flags+number of records owned
0011  order+ record type (0000 0000 0001 0001)
000e     下一個偏移量
--可變開銷(實際數據4字節)
80000001 (實際主鍵數據1其中8是符號位)
--固定開銷(4字節)
00000004 (葉子結點block指針)
我們可以看到這是非葉子結點存儲數據的格式如此,除了4字節的主鍵外,這里包含了10字節的額外開銷。
 
2、葉子結點如何存儲一行數據
接下來我們來看一下這個表的每一行數據是如何存放的,二進制如下:
./bcview testzh.ibd 16 120 31
current block:00000004--Offset:00120--cnt bytes:31--data is:00000010001f800000010000004d1995cd000001440110800046cd80000683
 
00 nullable field bitmap(?)
00 info flags+number of records owned
0010 order+record type
001f 下一個偏移量
80000001 (實際主鍵id數據1其中8是符號位)
0000004d1995  transaction id
cd000001440110 roll pointer
800046cd (實際數據id2:18125 8是符號位)
80000683 (實際數據id2:1667  8是符號位)
 
 
實際上就是31個字節
那么我們很容易計算出來如果滿存儲行大約(16*1024-128(塊頭塊尾部))/31 = 524 行數據。當然實際上存儲達不到這個值受到
B+樹分裂行為以及填充因子等限制實際上到不了這個值,我這里去大約500行數據
 
好了對于這張表這里我們可以實際大約計算一下理論值,實際值將略小:
 
一層B+樹     最大16K空間                                                                                         約500行數據
二層B+樹     最大約18M空間((16*1024-128)/14 * 16/1024 )                                         約58000行數據((16*1024-128)/14 *500)
三層B+樹     最大約21000M空間(power((16*1024-130)/14,2) * 16/1024)                       約673960500行數據(power((16*1024-130)/14,2) * 500)
四層B+樹     最大約24452000M空間(power((16*1024-130)/14,3) * 16/1024)                  約782468140500行數據(power((16*1024-130)/14,3) * 500)
 
 
但是要注意這里最大空間受到主鍵選擇影響很大,如果不是int為主鍵那么其非葉子結點一行數據將不會是14字節如果是long類型將是18字節,那么最大空間
將不會達到這么大,而行數更是受到實際一行數據大小限制,這里只是以文章開頭建立的表為列子。
本文最后更新于 2023-3-16 14:16,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:[email protected]
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

    熱門排行

      最近更新

        返回頂部
        主站蜘蛛池模板: 九九热精品免费观看 | 日韩成人在线视频 | 青娱乐极品视觉盛宴国产视频 | 沦为公交两奶头春药高潮迭起 | 久久99re2热在线播放7 | 精品久久免费视频 | 日本美国群交P片内射捆绑 日本毛片久久国产精品 | 国产最猛性XXXX69交 | 熟妇久久无码人妻AV蜜桃 | 琪琪SEE色原网色原网站18 | 久久99精品AV99果冻传媒 | 欧美精品专区免费观看 | 99在线免费 | 国模大胆一区二区三区 | 亚洲色图激情文学 | 免费韩伦影院在线观看 | 午夜家庭影院 | 古风H啪肉NP文 | 国产精品2020观看久久 | 欧美另类与牲交ZOZOZO | 日韩午夜欧美精品一二三四区 | ae58老司机福利 | 2017欧美狠狠色 | 91久久偷偷做嫩草影院免 | 学校女性奴sm训练调教 | 巨胸美乳中文在线观看 | 永久免费看mv网站入口 | 幸福草电视剧演员表介绍 | 国偷自产AV一区二区三区健身房 | 兔费看少妇性L交大片免费 偷偷要色偷偷 | 午夜天堂一区人妻 | 青青青久草 | 999国产高清在线精品 | 亚洲精品理论电影在线观看 | 亚洲三级在线中文字幕 | 99er久久国产精品在线 | 男人的天堂久久精品激情a 男人的天堂黄色片 | 国产精品久久久久久久久免费下载 | 精品99久久久久成人网站 | 国产一区二区三区影院 | 久久99影院 |