怎么在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下所有的统计信息进行导出导入:
--源端统计信息导出:beginDBMS_STATS.CREATE_STAT_TABLE('SYSTEM','JINGYU_STATS_20181217');DBMS_STATS.EXPORT_SCHEMA_STATS(OWNNAME=>'JINGYU',STATTAB=>'JINGYU_STATS_20181217',STATOWN=>'SYSTEM');end;/expdp\'/assysdba\'directory=xttsdumpfile=stats_jingyu.dmplogfile=stats_jingyu.logtables=system.jingyu_stats_20181217--目标端统计信息导入:impdp\'/assysdba\'directory=xttsdumpfile=stats_jingyu.dmplogfile=stats_jingyu.logcluster=nexecDBMS_STATS.IMPORT_SCHEMA_STATS(OWNNAME=>'JINGYU',STATTAB=>'JINGYU_STATS_20181217',STATOWN=>'SYSTEM');--删除存放统计信息的表(根据实际需要选择性执行):execDBMS_STATS.DROP_STAT_TABLE('SYSTEM','JINGYU_STATS_20181217');
2.示例database级别统计信息的导出导入
如果想将数据库所有统计信息进行导出导入,方法非常类似,使用对应的过程:
--源端统计信息导出:beginDBMS_STATS.CREATE_STAT_TABLE('SYSTEM','DB_STATS_20181217');DBMS_STATS.EXPORT_DATABASE_STATS(STATTAB=>'DB_STATS_20181217',STATOWN=>'SYSTEM');end;/expdp\'/assysdba\'directory=xttsdumpfile=stats.dmplogfile=stats.logtables=system.db_stats_20181217--目标端统计信息导入:impdp\'/assysdba\'directory=xttsdumpfile=stats.dmplogfile=stats.logcluster=nexecDBMS_STATS.IMPORT_DATABASE_STATS(STATTAB=>'DB_STATS_20181217',STATOWN=>'SYSTEM');--删除存放统计信息的表(根据实际需要选择性执行):execDBMS_STATS.DROP_STAT_TABLE('SYSTEM','DB_STATS_20181217');
3.验证统计信息导出导入效果
以数据库级别统计信息的导出导入为例,验证下实际的效果:
目前数据库JINGYU用户下各表在统计信息记录数:
SYS@orcl>selectowner,table_name,NUM_ROWSfromdba_tableswhereowner='JINGYU';OWNERTABLE_NAMENUM_ROWS----------------------------------------------------------------------JINGYUTEST100708JINGYUASH_TMP226
此时按照之前的步骤导出数据库的统计信息,步骤不再赘述。
然后在某一张表插入数据,重新收集该表的统计信息:
SYS@orcl>insertintojingyu.ash_tmpselect*fromjingyu.ash_tmp;SYS@orcl>commit;SYS@orcl>execdbms_stats.gather_table_stats('JINGYU','ASH_TMP');PL/SQLproceduresuccessfullycompleted.
再去查询统计信息记录的该表行数:
SYS@orcl>selectowner,table_name,num_rowsfromdba_tableswhereowner='JINGYU';OWNERTABLE_NAMENUM_ROWS----------------------------------------------------------------------JINGYUTEST100708JINGYUASH_TMP452
此时按照之前的步骤导入数据库的统计信息,步骤不再赘述。
再去查询统计信息记录的该表行数,已经恢复到当时的导出时刻:
SYS@orcl>selectowner,table_name,num_rowsfromdba_tableswhereowner='JINGYU';OWNERTABLE_NAMENUM_ROWS----------------------------------------------------------------------JINGYUTEST100708JINGYUASH_TMP226SYS@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
:
execdbms_stats.upgrade_stat_table('SYSTEM','db_stats_20181217');
关于怎么在Oracle中导出导入统计信息问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。