久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術(shù)干貨  > Mysql為什么只能支持2000w左右的數(shù)據(jù)量?

        Mysql為什么只能支持2000w左右的數(shù)據(jù)量?

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-10-11 22:19:01 1697033941

        一、Mysql為什么只能支持2000w左右的數(shù)據(jù)量

        簡而言之,是B+樹的層數(shù)問題。

        假設表中一行記錄的數(shù)據(jù)大小為1k(實際上現(xiàn)在很多互聯(lián)網(wǎng)業(yè)務數(shù)據(jù)記錄大小通常就是1K左右)

        所以(主鍵索引中)葉子節(jié)點的一個節(jié)點(即一個page,且為數(shù)據(jù)頁),在這里認為可以放16行記錄.

        假設主鍵ID為bigint類型(長度為8字節(jié)),而指針大小在InnoDB源碼中是6字節(jié),這樣一共14字節(jié),我們一個頁(Page,在此為目錄頁)中能存放多少這樣的(索引)單元,其實就代表有多少指針,即16384/14=1170。即一個目錄Page,能存大概1170個(索引)單元.

        那么可以算出一棵高度為2的B+樹,能存放1170*16=18720條這樣的數(shù)據(jù)記錄。

        根據(jù)同樣原理, 可以算出一個高度為3的B+樹可以存放:1170*1170*16=21902400條這樣的記錄。

        所以在InnoDB中B+樹高度一般為1-3層,就能滿足千萬級的數(shù)據(jù)存儲。在查找數(shù)據(jù)時一次頁的查找代表一次磁盤IO,所以通過主鍵索引查詢通常只需要1-3次IO操作即可查找到數(shù)據(jù)。

        所以如果 表A的數(shù)據(jù)行數(shù)為600多萬,B+樹高度為3;表B的數(shù)據(jù)行數(shù)只有15萬,B+樹高度也為3??梢钥闯霰M管數(shù)據(jù)量差異較大,這兩個表樹的高度都是3,換句話說這兩個表通過索引查詢效率并沒有太大差異,因為都只需要做3次IO。如果有一張表行數(shù)是一千萬,那么其B+樹高度依舊是3,查詢效率仍然不會相差太大。

        當然如果一張表只有5行數(shù)據(jù),那么它的B+樹高度為1。

        即當數(shù)據(jù)量在18720到21902400行之間時,B+樹的高度都是3,查詢的速度幾乎相同.

        因為二分查找是在內(nèi)存里邊進行的,速度很快.和磁盤IO差幾個數(shù)量級,可以忽略. 那么即從2萬行記錄到2200萬行記錄,主體的查詢性能差不多。

        延伸閱讀:

        二、數(shù)據(jù)庫的查詢功能實現(xiàn)原理

        數(shù)據(jù)庫查詢是數(shù)據(jù)庫的最主要功能之一。我們都希望查詢數(shù)據(jù)的速度能盡可能的快,因此數(shù)據(jù)庫系統(tǒng)的設計者會從查詢算法的角度進行優(yōu)化。最基本的查詢算法當然是順序查找(linear search),這種復雜度為O(n)的算法在數(shù)據(jù)量很大時顯然是糟糕的,好在計算機科學的發(fā)展提供了很多更優(yōu)異的查找算法,例如二分查找(binary search)、二叉樹查找(binary tree search)等。如果稍微分析一下會發(fā)現(xiàn),每種查找算法都只能應用于特定的數(shù)據(jù)結(jié)構(gòu)之上,例如二分查找要求被檢索數(shù)據(jù)有序,而二叉樹查找只能應用于二叉查找樹上,但是數(shù)據(jù)本身的組織結(jié)構(gòu)不可能完全滿足各種數(shù)據(jù)結(jié)構(gòu)(例如,理論上不可能同時將兩列都按順序進行組織),所以,在數(shù)據(jù)之外,數(shù)據(jù)庫系統(tǒng)還維護著滿足特定查找算法的數(shù)據(jù)結(jié)構(gòu),這些數(shù)據(jù)結(jié)構(gòu)以某種方式引用(指向)數(shù)據(jù),這樣就可以在這些數(shù)據(jù)結(jié)構(gòu)上實現(xiàn)高級查找算法。這種數(shù)據(jù)結(jié)構(gòu),就是索引。

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學 138****2860 剛剛成功領(lǐng)取
        王同學 131****2015 剛剛成功領(lǐng)取
        張同學 133****4652 剛剛成功領(lǐng)取
        李同學 135****8607 剛剛成功領(lǐng)取
        楊同學 132****5667 剛剛成功領(lǐng)取
        岳同學 134****6652 剛剛成功領(lǐng)取
        梁同學 157****2950 剛剛成功領(lǐng)取
        劉同學 189****1015 剛剛成功領(lǐng)取
        張同學 155****4678 剛剛成功領(lǐng)取
        鄒同學 139****2907 剛剛成功領(lǐng)取
        董同學 138****2867 剛剛成功領(lǐng)取
        周同學 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        永和县| 巴林右旗| 平江县| 东莞市| 定西市| 九龙县| 大城县| 福鼎市| 周至县| 义马市| 道真| 五家渠市| 金沙县| 宜昌市| 迁安市| 益阳市| 朝阳区| 岐山县| 咸丰县| 仁布县| 丰城市| 黔西| 拉萨市| 岑溪市| 静宁县| 田东县| 如皋市| 贵港市| 靖边县| 临泽县| 顺平县| 张家界市| 金沙县| 翁牛特旗| 江都市| 乌恰县| 达尔| 将乐县| 佛教| 金乡县| 东城区|