【oracle】統計資訊的恢復和備份

不一樣的天空w發表於2017-12-08
oracle 11g 增加了系統資訊的備份和恢復功能,分別是在系統級別,使用者級別,表級別!當我們對oracle 系統物件進行統計資訊收集時,為了防止新的統計資訊之後的執行計劃不如之前的,我們可以利用
dbms_stats.export_(database/schema/table)_stats 匯出統計資訊到建立的表中
dbms_stats.import_(database/schema/table)_stats 匯入統計資訊到系統中
來進行恢復統計資訊!
對統計資訊的備份和恢復包括如下等級
1)資料庫的統計資訊備份恢復(只能是sys使用者下)
exec dbms_stats.create_stat_table('sys','stat_sys');
exec dbms_stats.export_database_stats('stat_sys');
exec dbms_stats.import_database_stats('stat_sys');

2)方案的統計資訊備份恢復(只能在方案擁有者的使用者下,yang為使用者名稱)
exec dbms_stats.create_stat_table('yang','stat_2');
exec dbms_stats.export_schema_stats('yang','stat_2');
exec dbms_stats.import_schema_stats('yang','stat_2');

3)表的統計資訊備份恢復(只能在表擁有者的使用者下)
exec dbms_stats.create_stat_table('yang','stat_3');
exec dbms_stats.export_table_stats('yang','T1',null,'stat_3');
exec dbms_stats.import_table_stats('yang','T1',null,'stat_3');

下面針對使用者級別做一個測試!
1 建立統計資訊備份存放的表
yang@yangdb> exec dbms_stats.create_stat_table('yang','stat_4');
PL/SQL procedure successfully completed.

2 對使用者yang 進行統計,並將統計資訊匯出到表裡面!
yang@yangdb> begin
  2  dbms_stats.gather_schema_stats(
  3  ownname          => 'yang',
  4  estimate_percent => 100,
  5  method_opt       => 'for all columns size auto',
  6  degree           => 2);
  7  end;
  8  /
PL/SQL procedure successfully completed.
yang@yangdb> select table_name,last_analyzed from user_tables where table_name='T2';
TABLE_NAME                     LAST_ANALYZED
------------------------------ ------------------
T2                             27-FEB-12

yang@yangdb> exec dbms_stats.export_schema_stats('yang','stat_4');
PL/SQL procedure successfully completed.
3 刪除之前的統計資訊並查詢驗證
yang@yangdb> exec dbms_stats.delete_schema_stats('yang');
PL/SQL procedure successfully completed.
yang@yangdb> select table_name,last_analyzed from user_tables where table_name='T2';
TABLE_NAME                     LAST_ANALYZED
------------------------------ ------------------
T2

4 將之前備份的統計資訊從新匯入
yang@yangdb> exec dbms_stats.import_schema_stats('yang','stat_4');
PL/SQL procedure successfully completed.
查詢yang 使用者下的t2表的統計分析時間!
yang@yangdb> select table_name,last_analyzed from user_tables where table_name='T2';
TABLE_NAME                     LAST_ANALYZED
------------------------------ ------------------
T2                             27-FEB-12

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

相關文章