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

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

Oracle統(tǒng)計信息的導(dǎo)出導(dǎo)入測試示例詳解

2024-08-29 14:01:26
字體:
供稿:網(wǎng)友

背景:

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

Oracle提供給我們一些方法,比較常用的粒度有兩種:

  • schema級別統(tǒng)計信息的導(dǎo)出導(dǎo)入
    通過調(diào)用DBMS_STATS.EXPORT_SCHEMA_STATS和DBMS_STATS.IMPORT_SCHEMA_STATS來進(jìn)行。
  • database級別統(tǒng)計信息的導(dǎo)出導(dǎo)入
    通過調(diào)用DBMS_STATS.EXPORT_DATABASE_STATS和DBMS_STATS.IMPORT_DATABASE_STATS來進(jìn)行。

統(tǒng)計信息存放的表可以通過DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE來進(jìn)行創(chuàng)建或是刪除。

1.示例schema級別統(tǒng)計信息的導(dǎo)出導(dǎo)入

比如我將JINGYU這個schema下所有的統(tǒng)計信息進(jìn)行導(dǎo)出導(dǎo)入:

--源端統(tǒng)計信息導(dǎo)出: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--目標(biāo)端統(tǒng)計信息導(dǎo)入: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');--刪除存放統(tǒng)計信息的表(根據(jù)實際需要選擇性執(zhí)行):exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','JINGYU_STATS_20181217');

2.示例database級別統(tǒng)計信息的導(dǎo)出導(dǎo)入

如果想將數(shù)據(jù)庫所有統(tǒng)計信息進(jìn)行導(dǎo)出導(dǎo)入,方法非常類似,使用對應(yīng)的過程:

--源端統(tǒng)計信息導(dǎo)出: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--目標(biāo)端統(tǒng)計信息導(dǎo)入:impdp /'/ as sysdba/' directory=xtts dumpfile=stats.dmp logfile=stats.log cluster=nexec DBMS_STATS.IMPORT_DATABASE_STATS (STATTAB => 'DB_STATS_20181217', STATOWN => 'SYSTEM');--刪除存放統(tǒng)計信息的表(根據(jù)實際需要選擇性執(zhí)行):exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','DB_STATS_20181217');

3.驗證統(tǒng)計信息導(dǎo)出導(dǎo)入效果

以數(shù)據(jù)庫級別統(tǒng)計信息的導(dǎo)出導(dǎo)入為例,驗證下實際的效果:

目前數(shù)據(jù)庫JINGYU用戶下各表在統(tǒng)計信息記錄數(shù):

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

此時按照之前的步驟導(dǎo)出數(shù)據(jù)庫的統(tǒng)計信息,步驟不再贅述。

然后在某一張表插入數(shù)據(jù),重新收集該表的統(tǒng)計信息:

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.

再去查詢統(tǒng)計信息記錄的該表行數(shù):

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

此時按照之前的步驟導(dǎo)入數(shù)據(jù)庫的統(tǒng)計信息,步驟不再贅述。

再去查詢統(tǒng)計信息記錄的該表行數(shù),已經(jīng)恢復(fù)到當(dāng)時的導(dǎo)出時刻:

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> 

另外,需要注意如果統(tǒng)計信息導(dǎo)入的目標(biāo)環(huán)境,數(shù)據(jù)庫版本比源環(huán)境高(多發(fā)生在數(shù)據(jù)庫升級場景),導(dǎo)入統(tǒng)計信息時會遇到下面這樣的錯誤:

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

這時只需要按照提示執(zhí)行下 dbms_stats.upgrade_stat_table

exec dbms_stats.upgrade_stat_table('SYSTEM','db_stats_20181217');

再嘗試導(dǎo)入統(tǒng)計信息就可以成功了。

總結(jié)

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


注:相關(guān)教程知識閱讀請移步到oracle教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 草免费视频 | 午夜在线视频一区二区三区 | 最污网站 | 精品中文字幕久久久久四十五十骆 | 亚洲白嫩在线观看 | 国产亚洲精品美女久久久 | 成人免费毛片片v | 国产精品av久久久久久网址 | 黄色片在线播放 | 日本在线播放一区二区 | 国产超碰人人爽人人做人人爱 | 制服丝袜成人动漫 | 久久久久久久免费看 | 调教小男生抽打尿孔嗯啊视频 | 草莓视频在线导航 | 久久久一区二区三区四区 | h视频在线免费看 | 国产成人精品免高潮在线观看 | 在线2区| 人人舔人人舔 | 超碰在线97国产 | 精品国产一区二区三区在线观看 | 丰满年轻岳中文字幕一区二区 | 黄色免费电影网址 | 性插视频 | 国产一级在线看 | 二区三区四区视频 | 欧美性受xxx黑人xyx性爽 | 日本在线视频免费 | 国产在线精品一区二区三区不卡 | 亚洲精品a在线观看 | 国产亚洲精品综合一区91 | 伊人成人免费视频 | 欧美性色生活片免费播放 | 黄视频免费在线 | 一区二区三区手机在线观看 | 亚洲成人在线免费观看 | 在线播放黄色网址 | 国内精品伊人久久久久网站 | 九色中文| 成人做爰s片免费看网站 |