Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試示例詳解
背景:
有時(shí)我們會(huì)希望可以對(duì)Oracle的統(tǒng)計(jì)信息整體進(jìn)行導(dǎo)出導(dǎo)入。比如在數(shù)據(jù)庫(kù)遷移前后,希望統(tǒng)計(jì)信息保持不變;又比如想對(duì)統(tǒng)計(jì)信息重新進(jìn)行收集,但是擔(dān)心重新收集的結(jié)果反而引發(fā)性能問題,想先保存當(dāng)前的統(tǒng)計(jì)信息,這樣即使重新收集后效果不好還可以導(dǎo)入之前的統(tǒng)計(jì)信息。
Oracle提供給我們一些方法,比較常用的粒度有兩種:
- schema級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入
通過調(diào)用DBMS_STATS.EXPORT_SCHEMA_STATS和DBMS_STATS.IMPORT_SCHEMA_STATS來(lái)進(jìn)行。 - database級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入
通過調(diào)用DBMS_STATS.EXPORT_DATABASE_STATS和DBMS_STATS.IMPORT_DATABASE_STATS來(lái)進(jìn)行。
統(tǒng)計(jì)信息存放的表可以通過DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE來(lái)進(jìn)行創(chuàng)建或是刪除。
1.示例schema級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入
比如我將JINGYU這個(gè)schema下所有的統(tǒng)計(jì)信息進(jìn)行導(dǎo)出導(dǎo)入:
--源端統(tǒng)計(jì)信息導(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)計(jì)信息導(dǎo)入:
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');
--刪除存放統(tǒng)計(jì)信息的表(根據(jù)實(shí)際需要選擇性執(zhí)行):
exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','JINGYU_STATS_20181217');
2.示例database級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入
如果想將數(shù)據(jù)庫(kù)所有統(tǒng)計(jì)信息進(jìn)行導(dǎo)出導(dǎo)入,方法非常類似,使用對(duì)應(yīng)的過程:
--源端統(tǒng)計(jì)信息導(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)計(jì)信息導(dǎo)入:
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');
--刪除存放統(tǒng)計(jì)信息的表(根據(jù)實(shí)際需要選擇性執(zhí)行):
exec DBMS_STATS.DROP_STAT_TABLE ('SYSTEM','DB_STATS_20181217');
3.驗(yàn)證統(tǒng)計(jì)信息導(dǎo)出導(dǎo)入效果
以數(shù)據(jù)庫(kù)級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入為例,驗(yàn)證下實(shí)際的效果:
目前數(shù)據(jù)庫(kù)JINGYU用戶下各表在統(tǒng)計(jì)信息記錄數(shù):
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
此時(shí)按照之前的步驟導(dǎo)出數(shù)據(jù)庫(kù)的統(tǒng)計(jì)信息,步驟不再贅述。
然后在某一張表插入數(shù)據(jù),重新收集該表的統(tǒng)計(jì)信息:
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)計(jì)信息記錄的該表行數(shù):
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
此時(shí)按照之前的步驟導(dǎo)入數(shù)據(jù)庫(kù)的統(tǒng)計(jì)信息,步驟不再贅述。
再去查詢統(tǒng)計(jì)信息記錄的該表行數(shù),已經(jīng)恢復(fù)到當(dāng)時(shí)的導(dǎo)出時(shí)刻:
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>
另外,需要注意如果統(tǒng)計(jì)信息導(dǎo)入的目標(biāo)環(huán)境,數(shù)據(jù)庫(kù)版本比源環(huán)境高(多發(fā)生在數(shù)據(jù)庫(kù)升級(jí)場(chǎng)景),導(dǎo)入統(tǒng)計(jì)信息時(shí)會(huì)遇到下面這樣的錯(cuò)誤:
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
這時(shí)只需要按照提示執(zhí)行下 dbms_stats.upgrade_stat_table:
exec dbms_stats.upgrade_stat_table('SYSTEM','db_stats_20181217');
再嘗試導(dǎo)入統(tǒng)計(jì)信息就可以成功了。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
oracle group by語(yǔ)句實(shí)例測(cè)試
本文將詳細(xì)介紹oracle group by語(yǔ)句,以實(shí)例進(jìn)行測(cè)試,需要的朋友可以參考下2012-11-11
Oracle查詢優(yōu)化日期運(yùn)算實(shí)例詳解
這篇文章主要介紹了Oracle查詢優(yōu)化日期運(yùn)算實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05
Oracle遞歸查詢樹形數(shù)據(jù)實(shí)例代碼
Oracle數(shù)據(jù)庫(kù)中常要處理一些父子關(guān)系的記錄,在OLTP中要用得多一些,oracle提供了遞歸查詢可以很容易的滿足這個(gè)需求,下面這篇文章主要給大家介紹了關(guān)于Oracle遞歸查詢樹形數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-11-11
數(shù)據(jù)庫(kù)ORA-01196故障-歸檔日志丟失恢復(fù)詳解
這篇文章主要介紹了數(shù)據(jù)庫(kù)ORA-01196故障-歸檔日志丟失恢復(fù)詳解,具有一定參考價(jià)值,需要的朋友可以了解下。2017-10-10
PLSQL一些常用知識(shí)點(diǎn)梳理總結(jié)
這篇文章主要為大家介紹了PLSQL一些常用的知識(shí)點(diǎn)梳理總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
oracle的歸檔模式 ORACLE數(shù)據(jù)庫(kù)歸檔日志常用命令
Oracle數(shù)據(jù)庫(kù)有聯(lián)機(jī)重做日志,這個(gè)日志是記錄對(duì)數(shù)據(jù)庫(kù)所做的修改,比如插入,刪除,更新數(shù)據(jù)等,對(duì)這些操作都會(huì)記錄在聯(lián)機(jī)重做日志里2013-01-01
基于Oracle的面向?qū)ο蠹夹g(shù)入門基礎(chǔ)簡(jiǎn)析開發(fā)者網(wǎng)絡(luò)Oracle
基于Oracle的面向?qū)ο蠹夹g(shù)入門基礎(chǔ)簡(jiǎn)析開發(fā)者網(wǎng)絡(luò)Oracle...2007-03-03

