麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Oracle > 正文

Oracle統計信息的導出導入測試示例詳解

2020-07-26 13:59:16
字體:
來源:轉載
供稿:網友

背景:

有時我們會希望可以對Oracle的統計信息整體進行導出導入。比如在數據庫遷移前后,希望統計信息保持不變;又比如想對統計信息重新進行收集,但是擔心重新收集的結果反而引發性能問題,想先保存當前的統計信息,這樣即使重新收集后效果不好還可以導入之前的統計信息。

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=nexec 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=nexec 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        100708JINGYU       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        100708JINGYU       ASH_TMP        452

此時按照之前的步驟導入數據庫的統計信息,步驟不再贅述。

再去查詢統計信息記錄的該表行數,已經恢復到當時的導出時刻:

SYS@orcl> select owner, table_name, num_rows from dba_tables where owner='JINGYU';OWNER       TABLE_NAME      NUM_ROWS------------------------------ ------------------------------ ----------JINGYU       TEST        100708JINGYU       ASH_TMP        226SYS@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');

再嘗試導入統計信息就可以成功了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 粉嫩粉嫩一区二区三区在线播放 | 欧美精品成人一区二区在线观看 | 特色一级黄色片 | 国产午夜精品一区二区三区视频 | 欧美www| 亚洲欧美一区二区三区在线观看 | 免费毛片在线视频 | av免费在线播放网址 | 国产亚洲精品久久 | 91成人在线免费视频 | 国产手机av在线 | av在线观| 粉嫩一区 | 国内精品视频饥渴少妇在线播放 | 欧美性a视频 | 精品亚洲视频在线观看 | 亚洲精品7777 | 99精品国产一区二区三区 | 成人在线不卡 | 国产免费视频在线 | 欧美偷拍一区二区 | 精品国产91久久久久 | 日本免费a∨ | 97干色| 91成人亚洲 | 国产精品视频不卡 | 国产超碰人人做人人爱 | 精品亚洲福利一区二区 | 舌头伸进添的我好爽高潮网站 | 九一免费在线观看 | 欧美一级片免费在线观看 | 国产成年人网站 | www.理论片 | www.国产一区.com | 91精品国产综合久久青草 | 亚洲影视中文字幕 | 91精品观看91久久久久久国产 | 久久久国产精品电影 | 4480午夜| 色综合久久久久久久久久 | 国产1区在线观看 |