oracle區(qū)管理和段空間管理詳細(xì)介紹
更新時(shí)間:2012年11月20日 11:31:58 投稿:whsnow
本文將詳細(xì)介紹oracle區(qū)管理和段空間管理,需要的朋友可以參考下
作為一名DBA,常見的一個(gè)場景之一:
創(chuàng)建表空間:
復(fù)制代碼 代碼如下:
createtablespaceThink
datafile'/u01/app/oracle/oradata/orcl/think.dbf'size100M
autoextendonnext10Mmaxsize4096M
extentmanagementlocaluniformsize256K
segmentspacemanagementauto;
創(chuàng)建用戶:
復(fù)制代碼 代碼如下:
createuserbin
defaulttablespaceThink
temporarytablespacetemp;
授予權(quán)限:
復(fù)制代碼 代碼如下:
grantconnect,resourcetobin;
revokeunlimitedtablespacefrombin;
alteruserbinquotaunlimitedonThink;
在這個(gè)場景中,有兩條語句:
①extentmanagementlocaluniformsize256K
②segmentspacemanagementauto
其中,前者是區(qū)管理;后者則是段空間管理
㈠區(qū)管理
區(qū)管理實(shí)際上就是表空間的管理
8i以前,是字典管理表空間,當(dāng)創(chuàng)建或刪除對(duì)象時(shí),Oracle的空間分配或回收是通過數(shù)據(jù)字典來記錄和管理
在高并發(fā)系統(tǒng)中,這會(huì)導(dǎo)致性能衰減、空間碎片等難題
這已經(jīng)是門過去的技術(shù),這里就不贅述了。
8i開始,Oracle引入本地表空間管理
在每個(gè)表空間的數(shù)據(jù)文件的頭部加入了一個(gè)位圖區(qū)域
一個(gè)段的第一個(gè)區(qū)的第一個(gè)塊是firstlevelbitmapblock
第二個(gè)塊是secondlevelbitmapblock
第三個(gè)塊才是段頭塊
這兩個(gè)塊是用來管理freeblock
語法:
復(fù)制代碼 代碼如下:
extentmanagementlocal{autoallocate|uniformsizenK/M}
是自動(dòng)分配還是統(tǒng)一尺寸
若為自動(dòng)分配,則Oracle會(huì)按照遞增算法來分配空間
如果選擇統(tǒng)一尺寸,還可以詳細(xì)指定每個(gè)區(qū)間的大小
dba_extents這個(gè)視圖可以看到哪些對(duì)象分配了多少區(qū)間
㈡段空間管理
Oracle以區(qū)間為單位將空間分配給對(duì)象段,而段內(nèi)則是以block為單位進(jìn)行空間使用和管理
我們以幾個(gè)參數(shù)來理解段空間管理
復(fù)制代碼 代碼如下:
[sql]
<spanstyle="font-size:18px;">sys@ORCL>selectextent_management,segment_space_managementfromdba_tablespaces;
EXTENT_MANSEGMEN
----------------
LOCALMANUAL
LOCALMANUAL
LOCALAUTO
LOCALMANUAL
LOCALMANUAL
從9i開始,段空間管理有兩種:
①M(fèi)SSM:由你設(shè)置freelists、freelistgroups、pctused、pctfree、initrans等參數(shù)來控制如何分配、使用段中的空間
②ASSM:你只需控制一個(gè)參數(shù)pctfree,其他參數(shù)即使建了也將被忽略
⑴freelist
使用MSSM表空間管理時(shí),Oracle會(huì)在freelist中為有自由空間的對(duì)象維護(hù)HWM以下的塊
freelist和freelistgroup在ASSM表空間中根本不存在,僅在MSSM表空間使用這個(gè)技術(shù)
⑵pctfree和pctused
pctfree告訴Oracle:塊上應(yīng)該保留多大的空間來完成將來的更新
對(duì)于MSSM,她控制著塊何時(shí)放入freelist中,以及何時(shí)從freelist中取出。
如果大于pctfree,則這個(gè)塊會(huì)一直在freelist上
對(duì)于ASSM,因?yàn)锳SSM根本不使用freelist。在ASSM中,pctused也將被忽略。
但她仍然會(huì)限制能否將一個(gè)新行到一個(gè)塊中
適當(dāng)?shù)脑O(shè)置pctfree有助于減小行遷移
⑶initrans
無論是ASSMorMSSM這個(gè)參數(shù)仍然有效
塊頭的事務(wù)槽的初始化大小有對(duì)象的initrans指定
相關(guān)文章
Oracle數(shù)據(jù)塊實(shí)現(xiàn)原理深入解讀
Oracle對(duì)數(shù)據(jù)庫數(shù)據(jù)文件(datafile)中的存儲(chǔ)空間進(jìn)行管理的單位是數(shù)據(jù)塊(data block),本文將詳細(xì)介紹2012-11-11mybatis使用oracle進(jìn)行添加數(shù)據(jù)的方法
這篇文章主要介紹了mybatis使用oracle進(jìn)行添加數(shù)據(jù)的方法,本文給大家分享我的心得體會(huì),需要的朋友可以參考下2021-04-04oracle數(shù)據(jù)庫導(dǎo)出和oracle導(dǎo)入數(shù)據(jù)的二種方法(oracle導(dǎo)入導(dǎo)出數(shù)據(jù))
這篇文章主要介紹了oracle導(dǎo)入導(dǎo)出數(shù)據(jù)的二種方法,利用PL/SQL Developer工具導(dǎo)出和利用cmd的操作命令導(dǎo)出的出方法,大家參考使用吧2014-01-01Oracle數(shù)據(jù)泵實(shí)現(xiàn)不同用戶導(dǎo)入導(dǎo)出表級(jí)
這篇文章主要介紹了Oracle數(shù)據(jù)泵實(shí)現(xiàn)不同用戶導(dǎo)入導(dǎo)出表級(jí),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-07-07oracle數(shù)據(jù)庫遷移到MySQL的方法總結(jié)
本文主要總結(jié)了oracle數(shù)據(jù)庫遷移到MySQL的方法,方法包括手動(dòng)方式導(dǎo)入導(dǎo)出、使用工具Navicat 進(jìn)行導(dǎo)入、使用工具DBMover 的OracleToMySQL 進(jìn)行導(dǎo)入和使用工具intelligent-converters 的 oracle-to-mysql 進(jìn)行導(dǎo)入,需要的朋友可以參考下。2017-03-03Oracle數(shù)據(jù)庫用戶的密碼過期時(shí)間如何修改為永不過期
Oracle的密碼過期規(guī)則是用Profile來管理的,系統(tǒng)默認(rèn)只有一個(gè)Profile(DEFAULT),該profile的密碼過期規(guī)則為180天。那么如何修改Oracle數(shù)據(jù)庫用戶的密碼過期時(shí)間為永不過期呢?下面通過本文給大家介紹下2017-01-01