久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲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è)教育機(jī)構(gòu)

        手機(jī)站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

        千鋒教育

        掃一掃進(jìn)入千鋒手機(jī)站

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

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

        當(dāng)前位置:首頁  >  技術(shù)干貨  > 為什么列存儲(chǔ)數(shù)據(jù)庫(kù)讀取速度會(huì)比傳統(tǒng)的行數(shù)據(jù)庫(kù)快?

        為什么列存儲(chǔ)數(shù)據(jù)庫(kù)讀取速度會(huì)比傳統(tǒng)的行數(shù)據(jù)庫(kù)快?

        來源:千鋒教育
        發(fā)布人:xqq
        時(shí)間: 2023-10-12 22:26:32 1697120792

        一、為什么列存儲(chǔ)數(shù)據(jù)庫(kù)讀取速度會(huì)比傳統(tǒng)的行數(shù)據(jù)庫(kù)快

        列存儲(chǔ)的數(shù)據(jù)庫(kù)更適合OLAP,行存儲(chǔ)的數(shù)據(jù)庫(kù)更適合OLTP所謂的快只是針對(duì)于進(jìn)行olap操作而言。我們知道,數(shù)據(jù)在存儲(chǔ)中的基本單位為頁,這也是進(jìn)行數(shù)據(jù)讀取時(shí)候基本單位,一次讀取就是一次IO操作。

        以行方式查詢(在有適當(dāng)?shù)乃饕闆r下),那么,執(zhí)行一次以上查詢,只需要掃描一次page1就可以了。

        以列方式查詢,需要投其掃描page1 和page2共2次,分別取得字段1,字段2的單行值。

        OK,我們換成olap的典型查詢

        select avg(字段2) from table

        –(注意,這里假設(shè)字段2為一個(gè)整型數(shù)據(jù),而且無where條件限制,即需要掃描全部數(shù)據(jù))

        對(duì)于行存儲(chǔ),這個(gè)查詢需要兩次IO將全部數(shù)據(jù)放入內(nèi)存后,進(jìn)行頁間數(shù)據(jù)的跳讀(類隨機(jī)讀取),對(duì)于列存儲(chǔ),只需要一次IO將page2放入內(nèi)存后進(jìn)行連續(xù)讀取,如果字段2還有多頁的話,也都是進(jìn)行的物理連續(xù)讀取

        也就是說,在進(jìn)行olap操作時(shí)候,不僅是減小了IO次數(shù),而且把隨機(jī)讀取變?yōu)榱诉B續(xù)讀取。

        列式存儲(chǔ)把相同類型的數(shù)據(jù)歸在一起,壓縮比可以很高,通常能到10%~25%。數(shù)據(jù)庫(kù)的瓶頸通常在IO,很高的壓縮比,可以大大減輕數(shù)據(jù)讀取的壓力,提高響應(yīng)速度。

        除去字符串類型,其他類型的字段通常是固定長(zhǎng)度的,而且在磁盤和內(nèi)存的字節(jié)順序通常是一致的,可以直接映射,省去了解析的過程。而在行存儲(chǔ)中,只要有變長(zhǎng)的字段存在,需要逐行逐字段的解析。

        延伸閱讀:

        二、列存儲(chǔ)的特點(diǎn)

        在讀取數(shù)據(jù)時(shí),SQL?Server每次都把所需數(shù)據(jù)所在的整個(gè)Page讀取到內(nèi)存中,Page是數(shù)據(jù)讀取的最小單位。如果采用行存儲(chǔ),每一個(gè)Page都存儲(chǔ)所有列的數(shù)據(jù),每行的Size決定了單個(gè)Page能夠存儲(chǔ)的數(shù)據(jù)行數(shù)量。

        我們可以粗略計(jì)算一下,如果一個(gè)數(shù)據(jù)行有10列,每列的平均Size是10B,一行的Size是100B,那么單個(gè)Page非常多存儲(chǔ)80行(8060B/100B);如果采用列存儲(chǔ)模式,那么單個(gè)Page可以存儲(chǔ)806行(8060B/10B)。就單個(gè)Page存儲(chǔ)的數(shù)據(jù)行數(shù)量而言,列存儲(chǔ)是行存儲(chǔ)的10倍,SQL Server引擎把一個(gè)Page讀取到內(nèi)存中,能夠獲取的數(shù)據(jù)行數(shù)量成10倍增加。

        因此,采用列存儲(chǔ)模式時(shí),每一個(gè)Page能夠存儲(chǔ)更多的數(shù)據(jù)行。在加載列存儲(chǔ)數(shù)據(jù)時(shí),SQL Server只需要消耗少量的IO,就能把某一列的全部數(shù)據(jù)加載到緩存中。當(dāng)從列很多的大表中讀取幾個(gè)列時(shí),相比傳統(tǒng)的行存儲(chǔ)(Row Store)模式,列存儲(chǔ)(Column Store)能夠成千上萬倍地提高數(shù)據(jù)的讀取速度和查詢性能。

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        Web前端用來做什么?

        一、網(wǎng)頁開發(fā)Web前端在網(wǎng)頁開發(fā)中起到了至關(guān)重要的作用。它負(fù)責(zé)將網(wǎng)頁設(shè)計(jì)師設(shè)計(jì)的界面轉(zhuǎn)化為可交互的頁面。通過HTML、CSS和JavaScript等技術(shù),...詳情>>

        2023-10-12 23:57:56
        為什么要用flow?

        一、用flow的原因Flow是一種靜態(tài)類型檢查工具,用于JavaScript代碼。它的主要目的是幫助開發(fā)者在編寫JavaScript代碼時(shí)發(fā)現(xiàn)和預(yù)防類型相關(guān)的錯(cuò)誤...詳情>>

        2023-10-12 23:46:58
        OceanBase、TiDB這類NewSQL的定位是什么?

        一、OceanBase、TiDB這類NewSQL的定位oceanbase tidb spanner是share nothing的架構(gòu),單個(gè)分區(qū)有paxos保證可用性的前提下,還有近乎線性的擴(kuò)展...詳情>>

        2023-10-12 23:36:12
        linux有什么優(yōu)點(diǎn)?

        1、開源Linux的主要優(yōu)點(diǎn)之一是它是一個(gè)開放源代碼的操作系統(tǒng),即每個(gè)人都可以輕松獲得其源代碼。任何有編程能力的人都可以出于任何目的貢獻(xiàn),修...詳情>>

        2023-10-12 23:08:52
        Python特點(diǎn)及應(yīng)用?

        一、Python的特點(diǎn)Python是一種高級(jí)編程語言,由Guido van Rossum于上世紀(jì)90年代初開發(fā),它具有以下特點(diǎn):1、語法簡(jiǎn)潔易讀Python使用縮進(jìn)來表示...詳情>>

        2023-10-12 23:00:52
        快速通道
        拉萨市| 山东省| 龙游县| 承德县| 贺州市| 南乐县| 灵石县| 桃源县| 诸暨市| 怀仁县| 新平| 河南省| 阿勒泰市| 汉沽区| 珠海市| 潍坊市| 荆门市| 镇坪县| 苏尼特左旗| 巴彦县| 张家港市| 武城县| 罗源县| 济阳县| 鄂伦春自治旗| 大荔县| 修文县| 高安市| 淳化县| 南阳市| 含山县| 吉木萨尔县| 甘南县| 手游| 龙江县| 荆州市| 金寨县| 镇坪县| 卓资县| 金阳县| 眉山市|