濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試示例詳解

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

熱門標(biāo)簽:南寧人工智能電銷機(jī)器人費(fèi)用 安陽外呼系統(tǒng)免費(fèi) 分布式呼叫中心 400電話是不是免費(fèi)申請(qǐng) 貴陽電話外呼系統(tǒng)哪家好 呼倫貝爾智能手機(jī)地圖標(biāo)注 圖像地圖標(biāo)注 濟(jì)南地圖標(biāo)注公司 海南400電話哪里辦理

背景:

有時(shí)我們會(huì)希望可以對(duì)Oracle的統(tǒng)計(jì)信息整體進(jìn)行導(dǎo)出導(dǎo)入。比如在數(shù)據(jù)庫遷移前后,希望統(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來進(jìn)行。
  • database級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入
    通過調(diào)用DBMS_STATS.EXPORT_DATABASE_STATS和DBMS_STATS.IMPORT_DATABASE_STATS來進(jìn)行。

統(tǒng)計(jì)信息存放的表可以通過DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE來進(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ù)庫所有統(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ù)庫級(jí)別統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入為例,驗(yàn)證下實(shí)際的效果:

目前數(shù)據(jù)庫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ù)庫的統(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ù)庫的統(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ù)庫版本比源環(huán)境高(多發(fā)生在數(shù)據(jù)庫升級(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ì)腳本之家的支持。

您可能感興趣的文章:
  • JDBC Oracle執(zhí)行executeUpdate卡死問題的解決方案
  • ORACLE檢查找出損壞索引(Corrupt Indexes)的方法詳解
  • Oracle call 和 exec的詳解及區(qū)別
  • Oracle數(shù)據(jù)庫中 call 和 exec的區(qū)別
  • Oracle基礎(chǔ):通過sqlplus執(zhí)行sql語句后的結(jié)果進(jìn)行判斷
  • Oracle數(shù)據(jù)庫自動(dòng)備份腳本分享(超實(shí)用)
  • VMware下CentOS靜默安裝oracle12.2詳細(xì)圖文教程
  • ORACLE中關(guān)于表的一些特殊查詢語句
  • ORACLE中查找定位表最后DML操作的時(shí)間小結(jié)
  • 運(yùn)行在容器中的Oracle XE-11g

標(biāo)簽:涼山 南充 焦作 合肥 許昌 滁州 遼源 郴州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試示例詳解》,本文關(guān)鍵詞  Oracle,統(tǒng)計(jì),信息,的,導(dǎo)出,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試示例詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試示例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    安阳市| 南平市| 姚安县| 顺平县| 宣武区| 呼图壁县| 和静县| 曲靖市| 鹤壁市| 麦盖提县| 灵宝市| 琼海市| 襄垣县| 邹城市| 山阳县| 锡林浩特市| 宣武区| 绥中县| 项城市| 兴义市| 刚察县| 广宁县| 囊谦县| 和硕县| 鄂温| 攀枝花市| 晋宁县| 渝中区| 勃利县| 沙田区| 海口市| 宁乡县| 布尔津县| 商城县| 闸北区| 巴青县| 响水县| 辉县市| 九龙县| 印江| 广南县|