Oracle Database 10g:最佳新特性(第三周:表空間管理)
2024-08-29 13:49:07
供稿:網(wǎng)友
第三周:表空間治理
名字中包含了什么?:改善的表空間治理
表空間治理得到了重大的改進(jìn),這可以歸因于一個(gè) sparser SYSTEM、為用戶定義一個(gè)默認(rèn)表空間的支持、新的 SYSAUX、甚至重命名
您曾經(jīng)多少次因用戶在 SYSTEM 表空間中創(chuàng)建了非 SYS 和 SYSTEM 的段而傷透腦筋?
在 Oracle9i Database 之前,假如在創(chuàng)建用戶時(shí)沒(méi)有指定默認(rèn)表空間,那么它將默認(rèn)為 SYSTEM 表空間。假如用戶在創(chuàng)建一個(gè)段時(shí)沒(méi)有顯式地指定一個(gè)表空間,那么這個(gè)段將在 SYSTEM 中創(chuàng)建—前提是用戶在 SYSTEM 表空間中擁有配額(要么顯式地授予,要么通過(guò)系統(tǒng)權(quán)限 UNLIMITED TABLESPACE 來(lái)授予)。Oracle9i 答應(yīng) DBA 為所有未用顯式的臨時(shí)表空間子句創(chuàng)建的用戶指定一個(gè)默認(rèn)的臨時(shí)表空間,從而減少了這個(gè)問(wèn)題。
在 Oracle Database 10g 中,您可以類似地為用戶指定一個(gè)默認(rèn)表空間。在數(shù)據(jù)庫(kù)創(chuàng)建期間,CREATE DATABASE 命令可以包含子句 DEFAULT TABLESPACE 。在創(chuàng)建之后,您可以通過(guò)發(fā)出以下命令來(lái)使一個(gè)表空間變成默認(rèn)表空間
ALTER DATABASE DEFAULT TABLESPACE <tsname>;
未用 DEFAULT TABLESPACE 子句創(chuàng)建的所有用戶將以 作為它們的默認(rèn)表空間。您可以在任何時(shí)候通過(guò)這個(gè) ALTER 命令來(lái)改變默認(rèn)表空間,從而答應(yīng)您在不同的節(jié)點(diǎn)上將不同的表空間指定為默認(rèn)表空間。
重要注重事項(xiàng):擁有舊的表空間的所有用戶的默認(rèn)表空間都被修改為 ,即使有些表空間是為某些用戶顯式指定的。例如,假定用戶 USER1 和 USER2 的表空間分別是 TS1 和 TS2 — 它們是在用戶創(chuàng)建期間顯式指定的。數(shù)據(jù)庫(kù)當(dāng)前的默認(rèn)表空間是 TS2,但之后,數(shù)據(jù)庫(kù)的默認(rèn)表空間變?yōu)?TS1。即使 USER2 的默認(rèn)表空間是顯式指定為 TS2 的,它也將變?yōu)?TS1。小心這種邊界效應(yīng)!
假如在數(shù)據(jù)庫(kù)創(chuàng)建期間沒(méi)有指定默認(rèn)表空間,它將默認(rèn)為 SYSTEM。但您如何才能知道現(xiàn)有的數(shù)據(jù)庫(kù)的默認(rèn)表空間是哪一個(gè)?發(fā)出以下查詢:
SELECT PROPERTY_VALUEFROM DATABASE_PROPERTIESWHERE PROPERTY_NAME = 'DEFAULT_PERMANENT_TABLESPACE';
DATABASE_PROPERTIES 視圖顯示默認(rèn)表空間之外,還顯示一些非常重要的信息 — 例如默認(rèn)臨時(shí)表空間、全局?jǐn)?shù)據(jù)庫(kù)名、時(shí)區(qū)等。
非必要模式的默認(rèn)表空間
幾種模式(如智能代理用戶 DBSNMP、數(shù)據(jù)挖掘用戶 ODM)與用戶操作不直接相關(guān),但對(duì)數(shù)據(jù)庫(kù)完整性仍很重要。這些模式中的一些曾經(jīng)用 SYSTEM 作為它們的默認(rèn)表空間 — 這是在 SYSTEM 表空間內(nèi)對(duì)象增殖的又一個(gè)原因。
Oracle Database 10g 引進(jìn)了一個(gè)新的稱為 SYSAUX 的表空間,它用來(lái)保存這些模式的對(duì)象。這個(gè)表空間是在數(shù)據(jù)庫(kù)創(chuàng)建期間自動(dòng)創(chuàng)建的,并在本地進(jìn)行治理。唯一答應(yīng)修改的是數(shù)據(jù)文件的名稱。
這種方法在 SYSTEM 損壞需要完整的數(shù)據(jù)庫(kù)恢復(fù)時(shí),為恢復(fù)提供支持。SYSAUX 中的對(duì)象可以被恢復(fù)為任意正常的用戶對(duì)象,同時(shí)數(shù)據(jù)庫(kù)本身保持運(yùn)行。
但假如您想將 SYSAUX 中的這些模式中的一些轉(zhuǎn)移到一個(gè)不同的表空間中時(shí),該怎么辦?例如,考慮 LogMiner 使用的對(duì)象,這些對(duì)象的大小經(jīng)常增長(zhǎng),直到最終填滿表空間。出于可治理性的原因,您可能考慮將它們轉(zhuǎn)移到它們自己的表空間中。但實(shí)現(xiàn)這一目的的最好的方法是什么?
作為一個(gè)數(shù)據(jù)庫(kù)治理員,了解轉(zhuǎn)移這些非凡對(duì)象的正確過(guò)程對(duì)您而言是很重要的。幸運(yùn)的是,Oracle Database 10g 提供了一個(gè)新的視圖使要憑猜測(cè)來(lái)做的工作形象化。這個(gè)視圖,V$SYSAUX_OCCUPANTS,列出了表空間 SYSAUX 中的模式的名稱、它們的說(shuō)明、當(dāng)前使用的空間,以及如何轉(zhuǎn)移它們。(參見表 1。)
注重 LogMiner 如何被清楚地顯示為占用 7,488 KB 的空間。它歸模式 SYSTEM 所有,而要轉(zhuǎn)移對(duì)象,您需要執(zhí)行打包的過(guò)程 SYS.DBMS_LOGMNR_D.SET_TABLESPACE。不過(guò),對(duì)于 STATSPACK 對(duì)象,這個(gè)視圖推薦使用導(dǎo)入/導(dǎo)出方法;而對(duì)于流,沒(méi)有轉(zhuǎn)移過(guò)程 — 因而您不能輕易地將它們從 SYSAUX 表空間中轉(zhuǎn)移出來(lái)。列 MOVE_PROCEDURE 默認(rèn)顯示 SYSAUX 中存在的幾乎所有工具的正確的轉(zhuǎn)移過(guò)程。也可以逆向使用轉(zhuǎn)移過(guò)程來(lái)使對(duì)象回到 SYSAUX 表空間中。
重命名一個(gè)表空間
在數(shù)據(jù)倉(cāng)庫(kù)環(huán)境中(典型地,對(duì)于數(shù)據(jù)中心體系結(jié)構(gòu)),在數(shù)據(jù)庫(kù)之間傳輸表空間是很常見的。但源數(shù)據(jù)庫(kù)和目標(biāo)數(shù)據(jù)庫(kù)必須不存在擁有相同名稱的表空間。假如存在兩個(gè)擁有相同名稱的表空間,則目標(biāo)表空間中的段必須轉(zhuǎn)移到一個(gè)不同的表空間中,然后重新創(chuàng)建這個(gè)表空間— 這個(gè)任務(wù)說(shuō)起來(lái)輕易做起來(lái)難。
Oracle Database 10g 提供了一個(gè)方便的解決方案:您可以用以下命令來(lái)簡(jiǎn)單地重命名一個(gè)現(xiàn)有的表空間(SYSTEM 和 SYSAUX 除外) — 無(wú)論是永久表空間還是臨時(shí)表空間:
ALTER TABLESPACE <oldname> RENAME TO <newname>;
這個(gè)功能還將應(yīng)用在存檔過(guò)程中。假定您有一個(gè)按范圍分區(qū)的表,用于記錄銷售歷史數(shù)據(jù),每個(gè)月的這個(gè)分區(qū)位于按這個(gè)月份命名的一個(gè)表空間中 — 例如,1 月份的分區(qū)命名為 JAN,并位于一個(gè)名稱為 JAN 的表空間中。
這樣您就擁有了一個(gè)將信息保留 12 個(gè)月的策略。在 2004 年 1 月,您將能夠存檔 2003 年 1 月的數(shù)據(jù)。大致的操作流程類似于以下操作:
利用 ALTER TABLE EXCHANGE PARTITION 從分區(qū) JAN 中創(chuàng)建一個(gè)獨(dú)立的表 JAN03。 將表空間重命名為 JAN03。 為表空間 JAN03 創(chuàng)建一個(gè)可傳輸表空間集。 將表空間 JAN03 重新命名為 JAN。 將空的分區(qū)交換回表中。
第 1、2、4 和 5 步很簡(jiǎn)單,并且不會(huì)過(guò)度地消耗資源(如重做和撤消空間)。第 3 步只是拷貝文件并只為 JAN03 輸出數(shù)據(jù)字典信息,這也是個(gè)非常輕松的過(guò)程。假如您需要恢復(fù)之前存檔的分區(qū),這個(gè)過(guò)程也非常簡(jiǎn)單,您只需要將相同的過(guò)程反過(guò)來(lái)就行了。
Oracle Database 10g 在處理這些重命名的方式上相當(dāng)智能化。假如您重命名作為 UNDO 或默認(rèn)臨時(shí)表空間的表空間,這可能產(chǎn)生混淆。但數(shù)據(jù)庫(kù)將自動(dòng)調(diào)整必要的記錄來(lái)反映這種變化。例如,將默認(rèn)表空間的名稱從 USERS 修改為 USER_DATA 將自動(dòng)修改視圖 DATABASE_PROPERTIES。在修改之前,查詢:
select property_value from database_propertieswhere property_name = 'DEFAULT_PERMANENT_TABLESPACE';
返回 USERS。在運(yùn)行下面的語(yǔ)句之后
alter tablespace users rename to user_data;
上述查詢返回 USER_DATA,因?yàn)樗袑?duì) USERS 的引用都被修改為到 USER_DATA。
修改默認(rèn)臨時(shí)表空間的情況一樣。甚至修改 UNDO 表空間的名稱也將觸發(fā) SPFILE 中的變化,如下所示:
SQL> select value from v$spparameter where name = 'undo_tablespace';VALUE--------UNDOTBS1SQL> alter tablespace undotbs1 rename to undotbs;Tablespace altered.SQL> select value from v$spparameter where name = 'undo_tablespace';VALUE--------UNDOTBS
結(jié)論
在最近的幾個(gè) Oracle 版本演變的過(guò)程中,對(duì)象處理得到了穩(wěn)定的增強(qiáng)。Oracle8i 引進(jìn)了表從一個(gè)表空間到另一個(gè)表空間的轉(zhuǎn)移,Oracle 9i Database R2 引進(jìn)了列重命名,現(xiàn)在 — 在最新的版本中 — 表空間自身的重命名成為可能。這些增強(qiáng)顯著地減輕了數(shù)據(jù)庫(kù)治理員的任務(wù) — 非凡是在數(shù)據(jù)倉(cāng)庫(kù)或數(shù)據(jù)中心環(huán)境中。