溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思

發(fā)布時(shí)間:2021-12-13 11:50:34 來(lái)源:億速云 閱讀:1458 作者:小新 欄目:關(guān)系型數(shù)據(jù)庫(kù)

這篇文章主要介紹數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

一、數(shù)據(jù)塊(Block)

簡(jiǎn)介

數(shù)據(jù)塊Block是Oracle存儲(chǔ)數(shù)據(jù)信息的最小單位。注意,這里說(shuō)的是Oracle環(huán)境下的最小單位。Oracle也就是通過數(shù)據(jù)塊來(lái)屏蔽不同操作系統(tǒng)存儲(chǔ)結(jié)構(gòu)的差異。無(wú)論是他們的存儲(chǔ)結(jié)構(gòu)和方式、甚至字符排列的方式。

Oracle所有對(duì)數(shù)據(jù)的操作和空間分配,實(shí)際上都是針對(duì)數(shù)據(jù)塊Block的操作。我們從數(shù)據(jù)表中搜索出一行,實(shí)際中Oracle就會(huì)從內(nèi)存緩沖區(qū)(或者硬盤)中讀取到該行所在的數(shù)據(jù)塊,再返回這數(shù)據(jù)塊上的指定數(shù)據(jù)行。Oracle無(wú)論是在緩沖區(qū),還是在硬盤,進(jìn)行數(shù)據(jù)操作的雖小單位也就是數(shù)據(jù)塊。

參數(shù)

1、db_block_size

數(shù)據(jù)塊是有大小的,在一個(gè)數(shù)據(jù)庫(kù)建立的時(shí)候,通過參數(shù)進(jìn)行設(shè)置。數(shù)據(jù)塊的大小,在一個(gè)數(shù)據(jù)庫(kù)中可以支持多個(gè),但是一般沒有太大的意義,會(huì)給管理和調(diào)試帶來(lái)一定的負(fù)擔(dān)。

數(shù)據(jù)塊的大小是通過kb字節(jié)個(gè)數(shù)來(lái)指定的,默認(rèn)為8KB。相關(guān)參數(shù)為db_block_size。

設(shè)置數(shù)據(jù)塊的大小是依據(jù)不同類型的系統(tǒng)的。如果數(shù)據(jù)塊設(shè)置比較大,那么一次讀取的數(shù)據(jù)行較多,相應(yīng)對(duì)SGA內(nèi)存消耗比較大,特定查詢引發(fā)的換入換出可能較多。如果設(shè)置的過小,頻繁的IO邏輯物理讀也會(huì)引起性能問題。

2、db_file_multiblock_read_count

表示一次從物理存儲(chǔ)中讀取的數(shù)據(jù)塊數(shù)量。對(duì)一些數(shù)據(jù)挖掘系統(tǒng),可以考慮調(diào)節(jié)此參數(shù)略大一些。

二、區(qū)extent

簡(jiǎn)介

區(qū)extent是比數(shù)據(jù)塊大一級(jí)的存儲(chǔ)結(jié)構(gòu),表示的是一連串連續(xù)的數(shù)據(jù)塊集合。

在進(jìn)行存儲(chǔ)數(shù)據(jù)信息的時(shí)候,Oracle將分配數(shù)據(jù)塊進(jìn)行存儲(chǔ),但是不能保證所有分配的數(shù)據(jù)塊都是連續(xù)的結(jié)構(gòu)。所以,出現(xiàn)分區(qū)extent的概念,表示一系列連續(xù)的數(shù)據(jù)塊集合。

視圖

視圖dba_extents(或者all_extents、user_extents)是我們研究分區(qū)結(jié)構(gòu)和存儲(chǔ)構(gòu)成的重要手段。

數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思

1、分區(qū)是帶有段特定性的。數(shù)據(jù)段segment是分區(qū)的上層組織單位,一個(gè)數(shù)據(jù)庫(kù)對(duì)象對(duì)應(yīng)一個(gè)segement,數(shù)據(jù)庫(kù)對(duì)象是歸屬在不同的schema(owner)上的。所以,通過不同的數(shù)據(jù)段名稱、不同的owner,乃至不同的tablespace表空間信息,就可以定位到數(shù)據(jù)區(qū)extent的信息描述。

2、另一部分信息是關(guān)于該區(qū)extent的分配信息,如所在文件編號(hào),起始數(shù)據(jù)塊block編號(hào)和數(shù)據(jù)塊數(shù)量等內(nèi)容。

三、數(shù)據(jù)段segment

簡(jiǎn)介

數(shù)據(jù)段是與數(shù)據(jù)庫(kù)對(duì)象相對(duì)應(yīng),一般一個(gè)數(shù)據(jù)庫(kù)對(duì)象對(duì)應(yīng)一個(gè)數(shù)據(jù)段。多個(gè)extent是對(duì)應(yīng)一個(gè)數(shù)據(jù)段,每個(gè)數(shù)據(jù)段實(shí)際上就是數(shù)據(jù)庫(kù)一個(gè)對(duì)象的代表。

視圖

從dba_segments視圖中,可以比較清楚看清數(shù)據(jù)段的結(jié)構(gòu)。

數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思

1、從segment_type列的comment信息中,可以看出數(shù)據(jù)段的類型是多樣的。數(shù)據(jù)表、索引、回滾、聚集這些都是數(shù)據(jù)段的一種表現(xiàn)形式。同時(shí),數(shù)據(jù)段是在數(shù)據(jù)對(duì)象創(chuàng)建的時(shí)候就已經(jīng)創(chuàng)建出來(lái),隨著對(duì)象體積的增大,而不斷分配多個(gè)extents進(jìn)行管理。

2、另一部分信息可以從dba_segments中讀出的,就是該數(shù)據(jù)對(duì)象分配的空間大小和數(shù)據(jù)塊、分區(qū)個(gè)數(shù)。使用這個(gè)視圖,可以方便的獲取到指定schema的所有對(duì)象大小。

  1. SELECT OWNER,

  2.        SUM(BYTES) / 1024 / 1024 AS VOL,

  3.        SUM(BLOCKS) AS TOTALBLOCKS,

  4.        SUM(EXTENTS) AS TOTALEXTENTS

  5.   FROM DBA_SEGMENTS

  6.  GROUP BY OWNER

  7. HAVING OWNER = 'SYS';

一個(gè)數(shù)據(jù)對(duì)象對(duì)應(yīng)一個(gè)segment。但是,分區(qū)表的時(shí)候,一個(gè)分區(qū)要對(duì)應(yīng)一個(gè)segment對(duì)象。還有就是,segment對(duì)象是可以指定存儲(chǔ)在那個(gè)表空間里,實(shí)現(xiàn)存儲(chǔ)劃分的基礎(chǔ)也就在于此。不同類型的segment劃分建立在不同的表空間里,才有可能存放在不同的文件中,最后分布在不同的物理存儲(chǔ)。

四、表空間tablespace

簡(jiǎn)介

TableSpace是存儲(chǔ)結(jié)構(gòu)中的最高層結(jié)構(gòu)。建立一個(gè)表空間的時(shí)候,是需要指定存儲(chǔ)的文件。一個(gè)表空間可以指定多個(gè)數(shù)據(jù)文件,多個(gè)文件可以在不同的物理存儲(chǔ)上。但是有一點(diǎn)就是,表空間下一級(jí)對(duì)象數(shù)據(jù)段的存儲(chǔ),是不能指定存儲(chǔ)在那個(gè)文件里的。所以,要想讓數(shù)據(jù)對(duì)象訪問IO負(fù)載均衡,需要指定不同的數(shù)據(jù)對(duì)象在不同的表空間里。這也就是為什么將數(shù)據(jù)表和索引建立在不同的表空間的原因。

視圖

表空間通過v$tablespace進(jìn)行訪問。
數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思

數(shù)據(jù)文件通過v$datafile進(jìn)行訪問

數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思

以上是“數(shù)據(jù)庫(kù)中表空間、段、區(qū)、塊是什么意思”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI