【oracle】統計資訊的恢復和備份
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
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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle 9i統計資訊備份與恢復Oracle
- 備份恢復統計資訊 backup and restore statsREST
- Oracle 備份和恢復Oracle
- oracle冷備份、恢復和異機恢復Oracle
- Oracle 備份和恢復介紹Oracle
- Oracle備份恢復之熱備份恢復及異機恢復Oracle
- ORACLE備份和恢復 - 邏輯備份 exp/impOracle
- 備份和恢復
- CUUG筆記--oracle備份和恢復筆記Oracle
- oracle備份和恢復策略簡介Oracle
- Oracle備份和恢復工具介紹Oracle
- Oracle 9i備份和恢復Oracle
- Oracle 備份恢復概念Oracle
- oracle備份恢復PPTOracle
- ORACLE備份&恢復案例Oracle
- Backup And Recovery User's Guide-備份和恢復概覽-備份和恢復介紹-備份和恢復的目的GUIIDE
- 【備份恢復】Oracle 資料備份與恢復微實踐Oracle
- windwos server 路由備份和恢復 路由表備份和恢復Server路由
- NBU之oracle的備份恢復Oracle
- Oracle OCR的備份與恢復Oracle
- oracle備份恢復的大致原理!Oracle
- oracle rman備份恢復的例子Oracle
- redis 備份和恢復Redis
- 備份和恢復redisRedis
- Mysql備份和恢復MySql
- Oracle 11g RAMN恢復-控制檔案的備份和恢復Oracle
- ORACLE備份&恢復案例(轉)Oracle
- Oracle 備份 與 恢復 概述Oracle
- Oracle 備份恢復之 FlashbackOracle
- Oracle RAC備份與恢復Oracle
- ORACLE備份&恢復案例(3)Oracle
- ORACLE備份&恢復案例(5)Oracle
- ORACLE備份&恢復案例(4)Oracle
- ORACLE備份&恢復案例(7)Oracle
- ORACLE備份&恢復案例(6)Oracle
- ORACLE備份&恢復案例(8)Oracle
- ORACLE備份&恢復案例(1)Oracle
- ORACLE備份&恢復案例(2)Oracle