Oracle提高空間使用率的方法小結(jié)
一,行遷移和行鏈接
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)文章
Oracle數(shù)據(jù)回退的實(shí)現(xiàn)
在使用plsql工具,對(duì)表數(shù)據(jù)進(jìn)行操作后,提交了事務(wù),發(fā)現(xiàn)數(shù)據(jù)更新或者刪除錯(cuò)了,這時(shí)候還是有方法可以把數(shù)據(jù)回退的,本文就詳細(xì)的介紹此方法,感興趣的可以了解一下2023-08-08Oracle數(shù)據(jù)庫(kù)復(fù)雜度設(shè)置圖文教程
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)復(fù)雜度設(shè)置的相關(guān)資料,Oracle可以通過(guò)設(shè)置密碼復(fù)雜度來(lái)提高數(shù)據(jù)庫(kù)的安全性,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04oracle數(shù)據(jù)庫(kù)sql的優(yōu)化總結(jié)
自己對(duì)oracle sql的一些優(yōu)化總結(jié),特分享下,方便需要的朋友2013-08-08Oracle使用like查詢時(shí)對(duì)下劃線的處理方法
這篇文章主要介紹了Oracle使用like查詢時(shí)對(duì)下劃線的處理方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Oracle 低權(quán)限數(shù)據(jù)庫(kù)賬戶得到 OS 訪問(wèn)權(quán)限 提權(quán)利用
大概意思就是說(shuō),如果 ORACLE 服務(wù)是用 administrator 賬戶啟動(dòng)的,你只要有一個(gè)具有 resource 和 connect 權(quán)限的數(shù)據(jù)庫(kù)賬戶,就能利用 metasploit 的 smbrelay 功能,本地搭建一個(gè) SMB 欺騙服務(wù)器, 來(lái)得到系統(tǒng)的訪問(wèn)權(quán)限。2009-06-06oracle修改SGA后無(wú)法啟動(dòng)問(wèn)題分析及解決方法
oracle修改SGA后無(wú)法啟動(dòng),很郁悶的一個(gè)問(wèn)題,本文搜集整理了一下,感興趣的你不妨參考下,或許對(duì)你有所幫助哈2013-02-02oracle數(shù)據(jù)庫(kù)添加或刪除一列的sql語(yǔ)句
需要注意的一點(diǎn),如果要修改的表,不是當(dāng)前的用戶的表,那么就需要添加上用戶的名稱。以及有修改此表的權(quán)限2012-05-05Oracle的PDB數(shù)據(jù)庫(kù)創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問(wèn)題及解決方法
這篇文章主要介紹了Oracle的PDB數(shù)據(jù)庫(kù)創(chuàng)建DIRECTORY時(shí)遇到ORA-65254問(wèn)題,本文給大家分享完美解決方案,需要的朋友可以參考下2023-06-06oracle中得到一條SQL語(yǔ)句的執(zhí)行時(shí)間的兩種方式
這篇文章主要介紹了oracle中如何得到一條SQL語(yǔ)句的執(zhí)行時(shí)間,有兩種可行方式,大家可以參考下2014-05-05