a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

Oracle Database 10g:最佳新特性(第三周:表空間管理)

2024-08-29 13:49:07
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(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)境中。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 日韩激情视频一区二区 | 亚洲高清免费视频 | av在线二区| 欧美日韩二区三区 | 中文字幕在线不卡 | av毛片免费看 | 91视频电影 | 免费观看成人毛片 | 国产精品高清在线 | 国产一区二区在线播放 | 每日更新av | 欧美午夜精品久久久久久浪潮 | 午夜小视频在线观看 | 国内久久 | 成人精品在线 | 国产精品久久久久婷婷二区次 | 天堂亚洲 | 亚洲色图自拍 | 欧美日韩国产免费一区二区三区 | 91免费看电影 | 国产精品久久久久久久久久99 | 精品久久久久久久 | 啪啪tv网站免费入口 | 国产精品美女久久久久aⅴ国产馆 | 国产精品久久久久久久久 | 欧美一级黄色网 | 久久国产精品一区二区三区 | 欧美性v| 成人欧美一区二区三区在线湿哒哒 | 久草青青 | 久久精品久久综合 | 欧美高清成人 | 欧美日韩免费一区二区三区 | 欧美成人黄激情免费视频 | 亚洲一区二区三区视频免费观看 | 蜜桃视频麻豆女神沈芯语免费观看 | 精品国产一级毛片 | 男女瑟瑟网站 | 毛片在线免费 | 亚洲午夜成激人情在线影院 | 亚洲乱码一区二区三区在线观看 |