Oracle 12c 新特性之 資料庫內歸檔(In-Database Archiving)

張衝andy發表於2017-05-09
Oracle Database 12c中引入了 In-Database Archiving的新特性, 該特性允許使用者透過對錶上的資料行標記為inactive不活躍的,以歸檔資料。 這些inactive的資料行可以透過壓縮排一部最佳化,且對應用來說預設不可見。該特性可以對現有程式碼做最少改動的情況下,實現了這種“標記刪除”的功能和需求。

12c之前:
有些應用有“標記刪除”的概念,即不是刪除資料,而是資料依然保留在表中,只是對應用不可見而已。這種需求通常透過如下方法實現:
1)  給相關表增加一個另外的列,該列儲存標誌資料被刪除的標記。
2)  給每個語句增加一個謂詞,檢查被刪除行的狀態,像:“WHERE deleted = 'N'”,以便排除被刪除行。 謂詞能被硬編碼進SQL語句中,或動態應用類似VPD的安全策略。

12c之後:
1.   開啟資料庫內歸檔
ROW ARCHIVAL子句被用來開啟資料庫內歸檔。該子句可以用在建立表時用在CREATE TABLE中,也可以在表建立後用在ALTER TABLE中。

--建立表並開啟資料庫內歸檔特性
SQL>grant select on dba_objects to c##andy container=all;
SQL> conn c##andy/andy
Connected.
SQL>create table ida as select object_name,object_id from dba_objects where 1=2;
SQL>insert into ida select object_name,object_id from dba_objects order by object_id fetch first 10 percent rows only;
7281 rows created.
SQL> alter table ida ROW ARCHIVAL; 或者在建表的時候指定 create table (XXX) ROWARCHIVAL;
Table altered.
--檢查表內容
SQL>SELECT COUNT(*) FROM ida;
  COUNT(*)
----------
      7281
SQL> desc ida;
 Name   Null?    Type
 ----------------------------------------- -------- ----------------------------
 OBJECT_NAME    VARCHAR2(128)
 OBJECT_ID    NUMBER

開啟資料庫內歸檔特性將會引起表另外增加一個叫做“ORA_ARCHIVE_STATE”系統隱藏列。
SQL>
COL column_name FORMAT A20;
COL data_type FORMAT A20;
SELECT column_id,
column_name,
data_type,
data_length,
hidden_column
FROM user_tab_cols
WHERE table_name = 'IDA'
ORDER BY column_id;
COLUMN_ID COLUMN_NAME DATA_TYPE    DATA_LENGTH HID
---------- -------------------- -------------------- ----------- ---
1 OBJECT_NAME VARCHAR2     128 NO
2 OBJECT_ID NUMBER      22 NO
  SYS_NC00003$ RAW     126 YES
  ORA_ARCHIVE_STATEVARCHAR2    4000 YES

預設的,該列的每行被填充為‘0’。
SQL>
COL ora_archive_state FORMAT A20;
SELECT ora_archive_state,COUNT(*)
FROM ida
GROUP BY ora_archive_state
ORDER BY ora_archive_state;
ORA_ARCHIVE_STATE      COUNT(*)
-------------------- ----------
0   7281

2.   歸檔(刪除)的行
並非刪除不需要的行,而是把ORA_ARCHIVE_STATE系統隱藏列的值更改為‘1’。這將導致應用看不到這些行。
SQL>
UPDATE ida
SET ora_archive_state ='1'
WHERE object_id>7000;
284 rows updated.
SQL>COMMIT;

SQL>SELECT COUNT(*) FROM ida; 
  COUNT(*)
----------
      6997  > 已經出現隱藏列了

3.   顯示歸檔行
透過將ROW_ARCHIVAL_VISIBILITY設定為ALL,可以使得這些隱藏行對會話可見。將該引數設定回ACTIVE可以再次使這些行不可見。
--使歸檔的行可見
SQL>ALTER SESSION SET ROW ARCHIVAL VISIBILITY = ALL;
SQL>SELECT COUNT(*) FROM ida;
  COUNT(*)
----------

      7281     > 隱藏行對會話可見

--使歸檔行再次不可見
SQL>ALTER SESSION SET ROW ARCHIVAL VISIBILITY = ACTIVE;

SQL>SELECT COUNT(*) FROM ida;
  COUNT(*)
----------
      6997    > 隱藏行對會話不可見

--禁用並重新開啟資料庫內歸檔特性
SQL>ALTER TABLE ida NO ROW ARCHIVAL;
SQL>ALTER TABLE ida ROW ARCHIVAL;






來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31383567/viewspace-2138786/,如需轉載,請註明出處,否則將追究法律責任。

相關文章