欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle提高空間使用率的方法小結(jié)

 更新時(shí)間:2024年02月21日 09:10:23   作者:Dnui_King  
這篇文章給大家詳細(xì)介紹了Oracle 如何提高空間使用率,文中給大家總結(jié)了八種提高Oracle空間使用率的方法,并通過(guò)圖文講解的非常詳細(xì),需要的朋友可以參考下

一,行遷移和行鏈接

oracle盡量保證一行的數(shù)據(jù)能夠放在同一個(gè)數(shù)據(jù)塊當(dāng)中,有的時(shí)候行會(huì)發(fā)生行遷移和行鏈接。

行鏈接 :有一個(gè)列的字段是大對(duì)象(long,longlong)一行占的數(shù)據(jù)一整個(gè)塊都放不下,則oracle會(huì)把這行的數(shù)據(jù)分為兩部分或多部份,存放到不同的數(shù)據(jù)塊,這種現(xiàn)象叫做行鏈接。

行鏈接的缺陷顯而易見(jiàn),原本我只需要找到一個(gè)塊就能找到所有數(shù)據(jù),現(xiàn)在可能讀更多的塊才能夠找到數(shù)據(jù),增加了io。

行遷移:原本的行在一個(gè)數(shù)據(jù)塊中,如果我們?cè)谶@一行進(jìn)行了update操作,使得這一行的尺寸變大了

oracle在默認(rèn)情況下,如果這一行發(fā)生了增長(zhǎng),所需的多余空間會(huì)從這個(gè)塊的可用空間里面去獲取,這是最好的情況。但是如果這個(gè)塊可用的空間用滿了,則會(huì)發(fā)生行遷移。oracle會(huì)把這一行的數(shù)據(jù)遷移到一個(gè)新的數(shù)據(jù)塊,但是在原來(lái)的塊中會(huì)保留它的row id。

缺陷也是如此,原來(lái)只需要一次io,現(xiàn)在需要兩次io,降低了性能。

二,自動(dòng)段空間管理(Auto Segment Space Management)

簡(jiǎn)稱ASSM

段是oracle管理空間的一種機(jī)制

如果表空間是自動(dòng)管理的,則會(huì)用到位圖管理機(jī)制。

BMB(bitmap blocks) 在一個(gè)段中會(huì)有很多個(gè)位圖塊,在位圖中記錄了對(duì)應(yīng)塊的信息,如(剩余空間,可用空間,這個(gè)機(jī)制使得管理更加靈活)

總結(jié)一下就是:我們給段分配很多數(shù)據(jù)塊,oracle會(huì)拿出一些數(shù)據(jù)塊來(lái)記錄這些數(shù)據(jù)塊的使用情況,這些數(shù)據(jù)塊叫做:BMB(位圖塊)。

三,oracle表空間分配類型

主要分為兩種方式:1.uniform(固定分配)。2.autoallocate(自動(dòng)分配)

示例:

自動(dòng)分配:

固定分配:

四,使用 unusable索引

如果把一個(gè)索引變成unusable,oracle會(huì)把這個(gè)索引段刪掉,但是保留索引的定義,節(jié)省了空間,以后需要時(shí)可以用rebuild重建索引。

五,使用臨時(shí)表

臨時(shí)表只有在事務(wù)和會(huì)話過(guò)程中存在數(shù)據(jù)。

如果我們以后為了測(cè)試。表中的數(shù)據(jù)有沒(méi)有無(wú)所謂,我們可以基于有數(shù)據(jù)的表建一個(gè)臨時(shí)表,我們?cè)谂R時(shí)表上面進(jìn)行測(cè)試,退出會(huì)話時(shí)oracle會(huì)把這個(gè)臨時(shí)表刪掉。

臨時(shí)表有兩種類型:

Global:建的臨時(shí)表的定義所有的會(huì)話都可見(jiàn),內(nèi)容只有創(chuàng)建臨時(shí)表的會(huì)話看得見(jiàn),其它會(huì)話不可見(jiàn)

Private:只有創(chuàng)建臨時(shí)表的會(huì)話可見(jiàn),其它會(huì)話不可見(jiàn)。

臨時(shí)表的段只有在進(jìn)行第一次insert操作時(shí)才會(huì)分配,

創(chuàng)建全局臨時(shí)表:

插入數(shù)據(jù)后當(dāng)前會(huì)話可見(jiàn),其它會(huì)話不可見(jiàn)。

on commit delete 關(guān)鍵字:當(dāng)事務(wù)提交,臨時(shí)表數(shù)據(jù)全部刪除。

創(chuàng)建私有臨時(shí)表:

注意:私有臨時(shí)表 ,表名必須以  ORA$PTT_開(kāi)頭。

私有表前綴由private_temp_table_prefix 指定,可以自己指定

六,表壓縮

1.Basic table compression(基礎(chǔ)壓縮) 壓縮率:10倍

2.Advanced row compression(高級(jí)行壓縮) 壓縮率:2-4倍

壓縮原理:

Basic table compression 當(dāng)可用空間 是0 時(shí)觸發(fā)壓縮。

Advanced row compression 當(dāng)可用空間 剩余10% 觸發(fā)壓縮

例如:數(shù)據(jù)塊可用空間只剩下百分十10,觸發(fā)壓縮,把原來(lái)塊的數(shù)據(jù)進(jìn)行壓縮,騰出來(lái)一部分空間來(lái)存放新的數(shù)據(jù),再進(jìn)行insert操作后,可用空間又只剩下百分十10,再一次進(jìn)行壓縮。

總結(jié):oracle的壓縮原理是逐步壓縮。

basic壓縮:

空間大小比較:

注意如果使用 basic壓縮方式   使用insert方式進(jìn)行插入則不會(huì)進(jìn)行壓縮。

高級(jí)行壓縮:

不壓縮,插入數(shù)據(jù)十次:

 insert into EMP_NOCMP select * from emp_nocmp; (重復(fù) 10 次)

高級(jí)行壓縮,插入數(shù)據(jù)十次:

insert into EMP_CMP select * from emp_cmp; (重復(fù) 10 次)

所占空間對(duì)比:

比較清晰,高級(jí)行壓縮所占空間明顯減少。

表壓縮缺陷:

打開(kāi)計(jì)時(shí)器,對(duì)表進(jìn)行update操作,比對(duì)壓縮表和非壓縮表效率:

可見(jiàn)非壓縮表 update性能明顯高于壓縮表。

七,通過(guò) shringking 操作回收空間

只能對(duì)段空間管理方式為ASSM方式的表空間使用。

如果塊中發(fā)生大量的delete操作,導(dǎo)致塊中的行不緊湊,浪費(fèi)了大量塊空間,我們可以通過(guò)shringking 操作回收空間,降低高水位線,從而高水位線以上的塊就會(huì)被回收。

示例:創(chuàng)建一個(gè)表,表空間段空間管理為自動(dòng)管理,即ASSM,插入十五次數(shù)據(jù)。

insert into emp_shr select * from emp_shr;(執(zhí)行15次)

查看數(shù)據(jù)字典,該表占用空間情況:

進(jìn)行刪除操作,導(dǎo)致出現(xiàn)空閑空間。

讓表允許移動(dòng)行,否則無(wú)法使用shrink:

對(duì)表進(jìn)行shrink整理,查看數(shù)據(jù)字典。

發(fā)現(xiàn)此時(shí)空間并沒(méi)有被釋放,原因是我們的高水位線并沒(méi)有變低,只是把行變的緊湊了,沒(méi)有塊被oracle自動(dòng)回收。

改變高水位線,讓高水位線以上的空閑塊被oracle回收。

此時(shí),查看數(shù)據(jù)字典。

八,可恢復(fù)空間分配。

Oracle 數(shù)據(jù)庫(kù)服務(wù)器提供了一種暫停和稍后恢復(fù)執(zhí)行的方法空間分配失敗時(shí)的大型數(shù)據(jù)庫(kù) 操作。

簡(jiǎn)而言之:假如我們的表空間大小不夠了,正常來(lái)說(shuō)會(huì)直接報(bào)錯(cuò),假如我們執(zhí)行了兩個(gè)小時(shí)的inert操作,到最后因?yàn)楸砜臻g大小不足而導(dǎo)致操作失敗就很崩潰,所以oracle允許我們有補(bǔ)救措施。

resumable_timeout = 300;

假如我們的操作因?yàn)楸砜臻g大小不足,設(shè)置這個(gè)參數(shù)后不會(huì)立即報(bào)錯(cuò),而是會(huì)把這個(gè)事務(wù)掛起,在300s中,如果我們有補(bǔ)救措施,如resize表空間,增加了數(shù)據(jù)文件,使得表空間足夠進(jìn)行接下來(lái)的操作,該操作將繼續(xù)進(jìn)行。

如果300s之內(nèi)沒(méi)有補(bǔ)救,才會(huì)報(bào)錯(cuò),該操作失敗。

以上就是Oracle提高空間使用率的方法小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Oracle提高空間使用率的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論