亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > 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');

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

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品在线一区| 日韩在线免费观看视频| 少妇高潮久久77777| 国产精品美女久久久久久免费| 91精品久久久久久久久久久久久久| 欧美精品久久久久久久| 亚洲丝袜av一区| 国产一区视频在线| 国产精品电影观看| 亚洲福利在线看| 日本国产精品视频| 国产精品日日摸夜夜添夜夜av| 亚洲jizzjizz日本少妇| 91精品国产免费久久久久久| 欧美精品少妇videofree| 欧美日韩免费网站| 美女性感视频久久久| 亚洲欧美一区二区三区情侣bbw| 亚洲新声在线观看| 欧美激情成人在线视频| 91理论片午午论夜理片久久| 色一情一乱一区二区| 成人黄色在线观看| 成人激情视频免费在线| 97在线视频免费播放| 日韩大片免费观看视频播放| 午夜精品美女自拍福到在线| 亚洲成成品网站| 一区二区三区视频免费在线观看| 97超级碰在线看视频免费在线看| 91精品国产91久久| 欧美日韩国产一区二区三区| xxxx欧美18另类的高清| 欧美激情视频在线| 亚洲激情在线观看视频免费| 在线观看国产精品淫| 国产精品美女久久久久久免费| 成人免费视频xnxx.com| 久久成人18免费网站| 26uuu另类亚洲欧美日本老年| 免费不卡欧美自拍视频| 国产精品中文字幕久久久| 久久久久久久久综合| 欧美专区福利在线| 日韩中文字幕av| 久久亚洲精品视频| 成人欧美在线视频| 国产xxx69麻豆国语对白| 色综合久久悠悠| 亚洲综合色激情五月| 久久久噜久噜久久综合| 欧美一性一乱一交一视频| 日韩hd视频在线观看| 中国china体内裑精亚洲片| 日本一区二三区好的精华液| 日韩欧美在线网址| 亚洲国产欧美自拍| 成人a视频在线观看| 久久精品中文字幕电影| 91地址最新发布| 26uuu国产精品视频| 国产精品av在线播放| 欧美激情一区二区三区高清视频| 高清欧美电影在线| 欧美亚洲成人免费| 国产在线观看不卡| 欧洲午夜精品久久久| 久久久久久久久久亚洲| 久久国产天堂福利天堂| 国产精品观看在线亚洲人成网| 欧美激情免费视频| 国产精品免费一区| 欧美精品少妇videofree| 色综合久久88色综合天天看泰| 九九精品在线视频| 久久这里有精品视频| 亚洲精品98久久久久久中文字幕| 久久精品在线播放| 91大神福利视频在线| 国产成人精品免高潮费视频| 欧美另类69精品久久久久9999| 欧美性猛交xxxx免费看漫画| 中文国产亚洲喷潮| 米奇精品一区二区三区在线观看| 黑人巨大精品欧美一区二区| 日韩大片免费观看视频播放| 国产男女猛烈无遮挡91| 国产z一区二区三区| 国产精品白丝jk喷水视频一区| 国内精品视频久久| 在线精品视频视频中文字幕| 欧美日韩一区二区三区在线免费观看| 国产一区二区视频在线观看| 欧美激情综合亚洲一二区| 国产精品亚洲美女av网站| 日韩在线观看免费网站| 在线视频一区二区| 欧美一级淫片播放口| 欧美日韩国产丝袜另类| 久久久免费观看| 欧美第一黄网免费网站| 色偷偷91综合久久噜噜| 日韩**中文字幕毛片| 欧美丰满少妇xxxxx做受| 在线视频亚洲欧美| 国产在线拍偷自揄拍精品| 国产精品av网站| 在线精品国产欧美| 亚洲精品美女在线观看| 精品国产乱码久久久久久虫虫漫画| 色偷偷av亚洲男人的天堂| 韩国精品美女www爽爽爽视频| 亚洲国产精品中文| 1769国产精品| 国产日产欧美精品| xx视频.9999.com| 在线性视频日韩欧美| 97国产suv精品一区二区62| 国产成人精品优优av| 亚洲毛片在线看| 久久精品成人一区二区三区| 亚洲欧美中文日韩在线v日本| 色婷婷av一区二区三区在线观看| 一区二区三区国产在线观看| 欧美中文字幕视频在线观看| 欧美又大又粗又长| 日韩高清a**址| 国产激情久久久| 国产精品久久色| 中文字幕日韩在线观看| 三级精品视频久久久久| 日韩成人av一区| 午夜精品福利在线观看| 日韩欧美国产中文字幕| 国产精品美女久久久久av超清| 精品国内产的精品视频在线观看| 亚洲国产精品高清久久久| 日韩欧美a级成人黄色| 国产精品欧美久久久| 亚洲天堂网在线观看| 久久天天躁夜夜躁狠狠躁2022| 91国产美女视频| 国产亚洲aⅴaaaaaa毛片| 国产精品高精视频免费| 亚洲视频在线播放| 国产成人拍精品视频午夜网站| 中文字幕欧美日韩精品| 亚洲视频axxx| 欧美日韩中文字幕在线视频| 亚洲天天在线日亚洲洲精| 深夜福利一区二区| 51精品国产黑色丝袜高跟鞋| 国产香蕉精品视频一区二区三区| 国产精品亚洲аv天堂网| 欧美激情日韩图片| 欧美亚洲午夜视频在线观看| 欧美性感美女h网站在线观看免费| 久久久久久久久国产精品| 欧美精品免费在线观看| 亚洲天堂免费视频| 国产精品99久久久久久人| 91最新在线免费观看| 欧美成人精品h版在线观看| 亚洲激情在线观看|