Oracle 10G 中的資源回收筒

來源:互聯網
上載者:User
在Oracle 10G中,引入了一個資源回收筒(Recycle Bin)的概念.
  
  資源回收筒,從原理上來說就是一個資料字典表,放置使用者Drop掉的資料庫物件資訊.使用者進行Drop操作的對象並沒有被資料庫刪除,仍然會佔用空間.除非是由於使用者手工進行Purge或者因為儲存空間不夠而被資料庫清掉.資料庫有了這樣的功能,能夠減少很多不必要的麻煩.常常看到開發人員誤把表刪除,急急忙忙找DBA來想辦法的情況,相信,隨著10G的大範圍應用,這種情形應該比較少見了.
  
  DBA管理上的相關資訊可以從USER_recyclebin(DBA_recyclebin)中擷取.從現在的Beta版本來看,手冊上所說的通過SQL*Plus的show recycle bin 命令查看還不可用.
  
  為了便於測試,我們建立了一個資料表空間Foo,大小為1M,建立了一個使用者Foo,預設的資料表空間為Foo.

  ------------------------------------
  SQL> CONNECT foo/foo
  已串連。

  SQL> SELECT table_name FROM user_tables;

  未選定行

  SQL> DESC user_recyclebin
  名稱 是否為空白? 類型
  --------------------------------------
    ......
    ......
  user_recyclebin大多是自解釋的,涵義比較容易理解.

  SQL> SELECT object_name FROM user_recyclebin;

  未選定行

  SQL> CREATE TABLE foo AS SELECT * FROM DUAL;
 
  表已建立。

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  FOO

  SQL> DROP TABLE foo;

  表已丟棄。

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  RB$$41888$TABLE$0

  SQL>

  SQL> SELECT object_name, original_name FROM user_recyclebin;

  OBJECT_NAME ORIGINAL_NAME
  -------------------- --------------------
  RB$$41888$TABLE$0 FOO

  SQL> DESC RB$$41888$TABLE$0
  名稱 是否為空白? 類型
  ----------------------------------------

  DUMMY VARCHAR2(1)

  當一個表被刪除並移動到"資源回收筒"中,它的名字要進行一些轉換.這樣的目的顯而易見是為了避免同類對象名稱的重複.(Windows上,經過了特殊的處理,資源回收筒裡的作業系統檔案可以重名.)

  轉換後的名字格式如下:

  RB$$objn$object_type$version

  其中的RB,代表Recycle Bin. objn為表的目錄對象號. object_type表示物件類型. version表示版本號碼.

  由資料庫指定。foo表被刪除後,在資料庫資源回收筒裡變成了RB$$41888$TABLE$0 。從名字可以看出,這個對象的類型是Table,Version是0.

  SQL> CREATE TABLE foo AS SELECT * FROM DUAL;

  表已建立。

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  FOO
  RB$$41888$TABLE$0


 SQL> DROP TABLE foo;
 
  表已丟棄。

  SQL> SELECT object_name, original_name FROM user_recyclebin;

  OBJECT_NAME ORIGINAL_NAME
  -------------------- -------------
  RB$$41889$TABLE$0 FOO
  RB$$41888$TABLE$0 FOO

  SQL>

  能看出來,雖然源表名字相同,在資源回收筒裡的對象名字是不同的。

  已經放到資源回收筒裡的表是不能用drop 命令刪除的:
 
  SQL> drop table RB$$41888$TABLE$0;
  drop table RB$$41888$TABLE$0
  *
  ERROR 位於第 1 行:
  ORA-38301: can not perform DDL/DML over objects in Recycle Bin

  如果要清掉改對象,使用purge命令:

  SQL> PURGE table RB$$41888$TABLE$0;

  Table purged.

  SQL> SELECT object_name, original_name FROM user_recyclebin;

  OBJECT_NAME ORIGINAL_NAME
  -------------------- -----------------
  RB$$41889$TABLE$0 FOO

  對象已經清掉.

  恢複表,使用Undrop命令.

  SQL> undrop table RB$$41889$TABLE$0;

  Table undropped.

  SQL> SELECT object_name, original_name FROM user_recyclebin;

  未選定行

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  RB$$41889$TABLE$0

  SQL> desc foo;
  ERROR:
  ORA-04043: 對象 foo 不存在

  恢複後的表的名字為RB$$41889$TABLE$0,如果指定名字,使用" as 表名字 "
如: undrop table RB$$41889$TABLE$0 as Foo這樣的語句.更為詳細的文法,請查閱10G的SQL參考手冊.

  SQL>
  SQL> desc RB$$41889$TABLE$0;

  名稱 是否為空白? 類型
  ---------------------------------
  DUMMY VARCHAR2(1)

  SQL> DROP TABLE RB$$41889$TABLE$0;

  表已丟棄。

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  RB$$41889$TABLE$1

  SQL>

  如果我們這個時候再刪除RB$$41889$TABLE$0,可觀察到資源回收筒裡該表版本號碼的變化。

  如果空間一直夠用,資源回收筒裡的對象會一直保持(如果你不手工進行Purge的話)。如果空間不足,資源回收筒裡的對象會被清空。看我們下面這個例子:

  讓我們建立一個大一點的表:


 SQL> select object_name from user_recyclebin;

  OBJECT_NAME
  ------------------------------
  RB$$41893$TABLE$0

  SQL> CREATE TABLE foo_bigger AS SELECT * FROM all_objects WHERE ROWNUM<7980;

  表已建立。

  SQL> SELECT table_name FROM user_tables;

  TABLE_NAME
  ------------------------------
  FOO_BIGGER

  SQL> SELECT object_name, original_name FROM user_recyclebin;

  未選定行

  SQL>

  哦,果真,資源回收筒裡的內容已經被刪掉了。還要注意,在空間不足的時候Drop表,也是不能放到資源回收筒裡的。

  參考文檔:

  Oracle10i Database Administrator’s Guide Release 1 (10.1) - BETA
  Part No. B10739-01

  Oracle10g的undrop功能一點實踐 by Overmars



聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.