gpt4 book ai didi

Oracle统计信息的导出导入测试示例详解

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Oracle统计信息的导出导入测试示例详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

背景:

有时我们会希望可以对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下所有的统计信息进行导出导入:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
--源端统计信息导出:
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
 
--目标端统计信息导入:
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 ');
 
--删除存放统计信息的表(根据实际需要选择性执行):
exec DBMS_STATS.DROP_STAT_TABLE (' SYSTEM ',' JINGYU_STATS_20181217');

2.示例database级别统计信息的导出导入 。

如果想将数据库所有统计信息进行导出导入,方法非常类似,使用对应的过程:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
--源端统计信息导出:
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
 
--目标端统计信息导入:
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 ');
 
--删除存放统计信息的表(根据实际需要选择性执行):
exec DBMS_STATS.DROP_STAT_TABLE (' SYSTEM ',' DB_STATS_20181217');

3.验证统计信息导出导入效果 。

以数据库级别统计信息的导出导入为例,验证下实际的效果:

目前数据库JINGYU用户下各表在统计信息记录数:

?
1
2
3
4
5
6
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

此时按照之前的步骤导出数据库的统计信息,步骤不再赘述.

然后在某一张表插入数据,重新收集该表的统计信息:

?
1
2
3
4
5
6
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.

再去查询统计信息记录的该表行数

?
1
2
3
4
5
6
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

此时按照之前的步骤导入数据库的统计信息,步骤不再赘述.

再去查询统计信息记录的该表行数,已经恢复到当时的导出时刻:

?
1
2
3
4
5
6
7
8
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>

另外,需要注意如果统计信息导入的目标环境,数据库版本比源环境高(多发生在数据库升级场景),导入统计信息时会遇到下面这样的错误:

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:

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

再尝试导入统计信息就可以成功了.

总结 。

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我的支持.

原文链接:http://www.cnblogs.com/jyzhao/p/10137824.html 。

最后此篇关于Oracle统计信息的导出导入测试示例详解的文章就讲到这里了,如果你想了解更多关于Oracle统计信息的导出导入测试示例详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com