国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > 綜合 > 正文

名字中包含了什么?:改善的表空間管理

2024-07-21 02:33:37
字體:
來(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_VALUE
  FROM DATABASE_PROPERTIES
  WHERE 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)移它們。(參見(jià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ù)之間傳輸表空間是很常見(jiàn)的。但源數(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_properties
  where 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
  --------
  UNDOTBS1
  
  SQL> 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ā)表
主站蜘蛛池模板: 德州市| 时尚| 澄城县| 广汉市| 格尔木市| 通化县| 宜都市| 安康市| 贵南县| 游戏| 贞丰县| 永嘉县| 潢川县| 石渠县| 安新县| 彰武县| 永康市| 宝丰县| 邹城市| 临夏县| 榆中县| 夏津县| 曲沃县| 新和县| 柳州市| 石泉县| 玉山县| 桦川县| 六盘水市| 简阳市| 浦北县| 景谷| 嘉荫县| 九龙坡区| 张北县| 同德县| 光泽县| 香河县| 个旧市| 祁门县| 敦煌市|