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

首頁 > 數據庫 > Oracle > 正文

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

2024-08-29 14:01:26
字體:
來源:轉載
供稿:網友

背景:

有時我們會希望可以對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');

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

總結

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


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧洲国产精品| 九九久久国产精品| 日韩在线视频免费观看| 在线免费观看羞羞视频一区二区| 一区二区三区视频观看| 亚洲系列中文字幕| 青青久久av北条麻妃海外网| 精品国产视频在线| 国产一区二区日韩精品欧美精品| 国产日韩中文字幕| www.久久色.com| 国产欧美久久久久久| 欧美高清视频在线观看| 精品成人av一区| 色妞欧美日韩在线| 91精品在线国产| 国产成人91久久精品| 欧美精品videossex性护士| 午夜精品在线观看| 精品高清一区二区三区| 国产视频精品自拍| 欧美中在线观看| 亚洲美腿欧美激情另类| 理论片在线不卡免费观看| 亚洲www在线| 中文字幕亚洲一区二区三区| 欧美精品午夜视频| 欧美日韩一二三四五区| 国产精品视频自在线| 超碰91人人草人人干| 亚洲性夜色噜噜噜7777| 精品国产乱码久久久久久虫虫漫画| 亚洲影院污污.| 中日韩午夜理伦电影免费| 国产精品久久久久久久午夜| 亚洲九九九在线观看| 日韩中文字幕国产精品| 欧美极品在线播放| 欧美激情中文字幕在线| 欧美极品美女电影一区| 91精品国产综合久久香蕉的用户体验| 久久视频国产精品免费视频在线| 久久精品视频中文字幕| 国产成人精品免费久久久久| 国产有码一区二区| 国产精品久久久久99| 亚洲国产精品热久久| 亚洲精品视频二区| 国产日韩欧美在线| 亚洲欧美视频在线| 中文字幕欧美视频在线| 亚洲精品自拍第一页| 久久久久久久激情视频| 国产噜噜噜噜久久久久久久久| 最近更新的2019中文字幕| 欧美专区在线播放| 久久精品99久久久香蕉| 亚洲国产精品99| 国产亚洲一区二区在线| 午夜精品一区二区三区av| 国产亚洲精品综合一区91| 免费91麻豆精品国产自产在线观看| www.亚洲免费视频| 日韩av在线免播放器| 亚洲欧洲日产国码av系列天堂| 中文字幕在线成人| 精品国产鲁一鲁一区二区张丽| 欧美日韩电影在线观看| 日韩成人久久久| 欧美激情奇米色| 精品国产乱码久久久久酒店| 精品久久久精品| 欧美激情亚洲精品| 亚洲精品理论电影| 欧美激情在线播放| 欧美激情亚洲综合一区| 91久久嫩草影院一区二区| 亚洲精品福利资源站| 深夜成人在线观看| 欧美国产乱视频| 成人在线精品视频| 伊人久久久久久久久久久| 日韩二区三区在线| 久久91精品国产| 亚洲国产美女久久久久| 88xx成人精品| 国产精品99久久久久久白浆小说| 日韩免费av片在线观看| 久久久久久久久国产精品| 欧美在线视频网| 日韩精品免费在线视频观看| 成人午夜激情免费视频| 美女久久久久久久| 欧美成人久久久| 国产成人精品免费久久久久| 78色国产精品| 国产69精品久久久久99| 中文字幕欧美在线| 成人久久久久久| 亚洲视频在线视频| 精品亚洲夜色av98在线观看| 欧美亚洲日本网站| 欧美夫妻性生活视频| 日韩av片永久免费网站| 91精品国产综合久久男男| 亚洲欧美中文日韩在线| 91久久久久久久久久久久久| 91精品国产综合久久香蕉| 日韩欧美国产激情| 97视频在线免费观看| 久久精品国产96久久久香蕉| 国产亚洲欧洲高清| 2019日本中文字幕| 成人激情视频在线| 国产成人在线播放| 国产欧美一区二区| 亚洲影院色在线观看免费| 久久人91精品久久久久久不卡| 成人性生交xxxxx网站| 日本a级片电影一区二区| 国产一区二区在线播放| 不卡在线观看电视剧完整版| 久久久久久久av| 日韩精品欧美国产精品忘忧草| 国产视频亚洲视频| 韩国国内大量揄拍精品视频| 国产美女久久久| 日韩美女av在线| 日韩小视频在线| 人人做人人澡人人爽欧美| 久久电影一区二区| 美日韩精品视频免费看| 久久成年人视频| 亚洲天堂av在线播放| 富二代精品短视频| 日韩理论片久久| 亚洲丁香婷深爱综合| 亚洲精品99999| xxxxx91麻豆| 国产一区二区久久精品| 国产精品99久久99久久久二8| 欧美日韩视频在线| 中文字幕欧美日韩va免费视频| 欧美性色19p| 日韩欧美中文字幕在线观看| 亚洲精品国产精品久久清纯直播| 成人www视频在线观看| 国产欧美欧洲在线观看| 亚洲国产欧美在线成人app| 亚洲欧美日本另类| 欧美亚洲在线视频| 国产成人精品综合久久久| 成人国产精品久久久久久亚洲| 国内偷自视频区视频综合| 精品久久久中文| 九九热精品视频国产| 亚洲图片欧洲图片av| 国产精品网红直播| 欧美性高跟鞋xxxxhd| 国产精品99免视看9| 日韩大胆人体377p| 亚洲福利影片在线| 日本一区二区在线免费播放| 欧美日韩国产精品一区二区不卡中文|