欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年12月24日 08:33:09   作者:AlfredZhao  
這篇文章主要給大家介紹了關(guān)于Oracle統(tǒng)計(jì)信息的導(dǎo)出導(dǎo)入測(cè)試的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

背景:

有時(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來進(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ù)庫(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表空間的創(chuàng)建、使用、重命名與刪除方法

    Oracle表空間的創(chuàng)建、使用、重命名與刪除方法

    表空間是Oracle數(shù)據(jù)庫(kù)中的一個(gè)重要概念,它是一組物理文件,用于存儲(chǔ)數(shù)據(jù)庫(kù)對(duì)象,如表、索引等,在使用Oracle數(shù)據(jù)庫(kù)時(shí),通常需要?jiǎng)?chuàng)建表空間來存放數(shù)據(jù),本文介紹了Oracle表空間的創(chuàng)建、使用、重命名與刪除方法
    2024-03-03
  • 淺談oracle rac和分布式數(shù)據(jù)庫(kù)的區(qū)別

    淺談oracle rac和分布式數(shù)據(jù)庫(kù)的區(qū)別

    這篇文章主要介紹了oracle rac和分布式數(shù)據(jù)庫(kù)的區(qū)別的相關(guān)內(nèi)容,小編覺得挺不錯(cuò)的,這里給大家分享下,需要的朋友可以參考。
    2017-10-10
  • Oracle給用戶授權(quán)truncatetable的實(shí)現(xiàn)方案

    Oracle給用戶授權(quán)truncatetable的實(shí)現(xiàn)方案

    這篇文章主要介紹了Oracle給用戶授權(quán)truncatetable的實(shí)現(xiàn)方案,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-05-05
  • oracle中to_date詳細(xì)用法示例(oracle日期格式轉(zhuǎn)換)

    oracle中to_date詳細(xì)用法示例(oracle日期格式轉(zhuǎn)換)

    這篇文章主要介紹了oracle中to_date詳細(xì)用法示例,包括期和字符轉(zhuǎn)換函數(shù)用法、字符串和時(shí)間互轉(zhuǎn)、求某天是星期幾、兩個(gè)日期間的天數(shù)、月份差等用法
    2014-01-01
  • 詳解oracle管道函數(shù)的用法(一行拆為多行)

    詳解oracle管道函數(shù)的用法(一行拆為多行)

    這篇文章主要介紹了oracle管道函數(shù)的用法(一行拆為多行),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • oracle 發(fā)送郵件 實(shí)現(xiàn)方法

    oracle 發(fā)送郵件 實(shí)現(xiàn)方法

    oracle 發(fā)送郵件 實(shí)現(xiàn)方法
    2009-05-05
  • Oracle監(jiān)控?cái)?shù)據(jù)庫(kù)性能的方法步驟

    Oracle監(jiān)控?cái)?shù)據(jù)庫(kù)性能的方法步驟

    監(jiān)控?cái)?shù)據(jù)庫(kù)性能是確保數(shù)據(jù)庫(kù)系統(tǒng)高效運(yùn)行并快速響應(yīng)用戶請(qǐng)求的關(guān)鍵步驟,有效的數(shù)據(jù)庫(kù)性能監(jiān)控可以幫助識(shí)別和解決性能瓶頸,預(yù)測(cè)潛在問題,并優(yōu)化資源使用,以下是詳細(xì)的步驟和代碼示例,指導(dǎo)你如何監(jiān)控?cái)?shù)據(jù)庫(kù)性能,需要的朋友可以參考下
    2024-08-08
  • oracle添加序號(hào)列3種方法大全

    oracle添加序號(hào)列3種方法大全

    Oracle是眾多的關(guān)系型數(shù)據(jù)庫(kù)系統(tǒng)之一,它可以為表格中的每一行創(chuàng)建唯一的序號(hào)列,這篇文章主要給大家介紹了關(guān)于oracle添加序號(hào)列的3種方法大全,需要的朋友可以參考下
    2024-03-03
  • Oracle Max函數(shù)使用中出現(xiàn)的問題

    Oracle Max函數(shù)使用中出現(xiàn)的問題

    在Oracle Max函數(shù)使用中,會(huì)出現(xiàn)一些問題,本文將介紹解決方法,需要的朋友可以了解下
    2012-11-11
  • Oracle分頁查詢的實(shí)例詳解

    Oracle分頁查詢的實(shí)例詳解

    這篇文章主要介紹了Oracle分頁查詢的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)理解這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10

最新評(píng)論