您好,登錄后才能下訂單哦!
怎么在Oracle中導出導入統計信息?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
schema級別統計信息的導出導入
通過調用DBMS_STATS.EXPORT_SCHEMA_STATS和DBMS_STATS.IMPORT_SCHEMA_STATS
來進行。
database級別統計信息的導出導入
通過調用DBMS_STATS.EXPORT_DATABASE_STATS和DBMS_STATS.IMPORT_DATABASE_STATS
來進行。
統計信息存放的表可以通過DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE
來進行創建或是刪除。
1.示例schema級別統計信息的導出導入
比如我將JINGYU這個schema下所有的統計信息進行導出導入:
--源端統計信息導出: begin DBMS_STATS.CREATE_STAT_TABLE('SYSTEM','JINGYU_STATS_20181217'); DBMS_STATS.EXPORT_SCHEMA_STATS(OWNNAME => 'JINGYU', STATTAB => 'JINGYU_STATS_20181217', STATOWN => 'SYSTEM'); end; / expdp \'/ as sysdba\' directory=xtts dumpfile=stats_jingyu.dmp logfile=stats_jingyu.log tables=system.jingyu_stats_20181217 --目標端統計信息導入: impdp \'/ as sysdba\' directory=xtts dumpfile=stats_jingyu.dmp logfile=stats_jingyu.log cluster=n exec DBMS_STATS.IMPORT_SCHEMA_STATS (OWNNAME => 'JINGYU', STATTAB => 'JINGYU_STATS_20181217', STATOWN => 'SYSTEM'); --刪除存放統計信息的表(根據實際需要選擇性執行): exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','JINGYU_STATS_20181217');
2.示例database級別統計信息的導出導入
如果想將數據庫所有統計信息進行導出導入,方法非常類似,使用對應的過程:
--源端統計信息導出: begin DBMS_STATS.CREATE_STAT_TABLE('SYSTEM','DB_STATS_20181217'); DBMS_STATS.EXPORT_DATABASE_STATS(STATTAB => 'DB_STATS_20181217', STATOWN => 'SYSTEM'); end; / expdp \'/ as sysdba\' directory=xtts dumpfile=stats.dmp logfile=stats.log tables=system.db_stats_20181217 --目標端統計信息導入: impdp \'/ as sysdba\' directory=xtts dumpfile=stats.dmp logfile=stats.log cluster=n exec DBMS_STATS.IMPORT_DATABASE_STATS (STATTAB => 'DB_STATS_20181217', STATOWN => 'SYSTEM'); --刪除存放統計信息的表(根據實際需要選擇性執行): exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','DB_STATS_20181217');
3.驗證統計信息導出導入效果
以數據庫級別統計信息的導出導入為例,驗證下實際的效果:
目前數據庫JINGYU用戶下各表在統計信息記錄數:
SYS@orcl> select owner, table_name, NUM_ROWS from dba_tables where owner = 'JINGYU'; OWNER TABLE_NAME NUM_ROWS ------------------------------ ------------------------------ ---------- JINGYU TEST 100708 JINGYU ASH_TMP 226
此時按照之前的步驟導出數據庫的統計信息,步驟不再贅述。
然后在某一張表插入數據,重新收集該表的統計信息:
SYS@orcl> insert into jingyu.ash_tmp select * from jingyu.ash_tmp; SYS@orcl> commit; SYS@orcl> exec dbms_stats.gather_table_stats('JINGYU','ASH_TMP'); PL/SQL procedure successfully completed.
再去查詢統計信息記錄的該表行數:
SYS@orcl> select owner, table_name, num_rows from dba_tables where owner='JINGYU'; OWNER TABLE_NAME NUM_ROWS ------------------------------ ------------------------------ ---------- JINGYU TEST 100708 JINGYU ASH_TMP 452
此時按照之前的步驟導入數據庫的統計信息,步驟不再贅述。
再去查詢統計信息記錄的該表行數,已經恢復到當時的導出時刻:
SYS@orcl> select owner, table_name, num_rows from dba_tables where owner='JINGYU'; OWNER TABLE_NAME NUM_ROWS ------------------------------ ------------------------------ ---------- JINGYU TEST 100708 JINGYU ASH_TMP 226 SYS@orcl>
另外,需要注意如果統計信息導入的目標環境,數據庫版本比源環境高(多發生在數據庫升級場景),導入統計信息時會遇到下面這樣的錯誤:
ERROR at line 1:
ORA-20002: Version of statistics table SYSTEM.DB_STATS_20181217 is too old.
Please try upgrading it with dbms_stats.upgrade_stat_table
ORA-06512: at "SYS.DBMS_STATS", line 11648
ORA-06512: at "SYS.DBMS_STATS", line 11665
ORA-06512: at "SYS.DBMS_STATS", line 12800
ORA-06512: at line 1
這時只需要按照提示執行下 dbms_stats.upgrade_stat_table
:
exec dbms_stats.upgrade_stat_table('SYSTEM','db_stats_20181217');
關于怎么在Oracle中導出導入統計信息問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。