怎么在Oracle中导出导入统计信息

  介绍

怎么在Oracle中导出导入统计信息?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

<李>

模式级别统计信息的导出导入
  ,通过调用<代码> DBMS_STATS.EXPORT_SCHEMA_STATS和DBMS_STATS.IMPORT_SCHEMA_STATS> <李>

数据库级别统计信息的导出导入
  ,通过调用<代码> DBMS_STATS.EXPORT_DATABASE_STATS和DBMS_STATS.IMPORT_DATABASE_STATS>

统计信息存放的表可以通过<代码> DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE>

<强> 1。示例模式级别统计信息的导出导入

比如我将宇这个模式下所有的统计信息进行导出导入:

——源端统计信息导出:   开始   ,DBMS_STATS.CREATE_STAT_TABLE(& # 39;系统# 39;,& # 39;JINGYU_STATS_20181217& # 39;),,   ,DBMS_STATS.EXPORT_SCHEMA_STATS (OWNNAME =祝辞,& # 39;宇# 39;,,STATTAB =祝辞,& # 39;JINGYU_STATS_20181217& # 39;,, STATOWN =祝辞,& # 39;系统# 39;);   结束;/expdp  \ & # 39;/, as  sysdba \ & # 39;,目录=xtts  dumpfile=stats_jingyu.dmp =system.jingyu_stats_20181217日志文件=stats_jingyu.log 表      ——目标端统计信息导入:   impdp  \ & # 39;/, as  sysdba \ & # 39;,目录=xtts  dumpfile=stats_jingyu.dmp 日志文件=stats_jingyu.log 集群=n   exec  DBMS_STATS.IMPORT_SCHEMA_STATS  (OWNNAME =祝辞,& # 39;宇# 39;,,STATTAB =祝辞,& # 39;JINGYU_STATS_20181217& # 39;,, STATOWN =祝辞,& # 39;系统# 39;);      ——删除存放统计信息的表(根据实际需要选择性执行):   exec  DBMS_STATS.DROP_STAT_TABLE (& # 39;系统# 39;& # 39;JINGYU_STATS_20181217& # 39;);

<强> 2。示例数据库级别统计信息的导出导入

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

——源端统计信息导出:   开始   ,DBMS_STATS.CREATE_STAT_TABLE(& # 39;系统# 39;,& # 39;DB_STATS_20181217& # 39;),,   ,DBMS_STATS.EXPORT_DATABASE_STATS (STATTAB =祝辞,& # 39;DB_STATS_20181217& # 39;,, STATOWN =祝辞,& # 39;系统# 39;);   结束;/expdp  \ & # 39;/, as  sysdba \ & # 39;,目录=xtts  dumpfile=stats.dmp =system.db_stats_20181217日志文件=stats.log 表      ——目标端统计信息导入:   impdp  \ & # 39;/, as  sysdba \ & # 39;,目录=xtts  dumpfile=stats.dmp 日志文件=stats.log 集群=n   exec  DBMS_STATS.IMPORT_DATABASE_STATS  (STATTAB =祝辞,& # 39;DB_STATS_20181217& # 39;,, STATOWN =祝辞,& # 39;系统# 39;);      ——删除存放统计信息的表(根据实际需要选择性执行):   exec  DBMS_STATS.DROP_STAT_TABLE (& # 39;系统# 39;& # 39;DB_STATS_20181217& # 39;);

<强> 3。验证统计信息导出导入效果

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

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

SYS@orcl>, select 所有者,table_name,, NUM_ROWS 得到dba_tables  where  owner =, & # 39;宇# 39;;      OWNER ,,,,,, TABLE_NAME ,,,, NUM_ROWS   - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -,- - - - - - - - - - - - - - - - - - - - - - - - - - - - - -,- - - - - - - - - - -   JINGYU ,,,,,, TEST ,,,,,,, 100708   JINGYU ,,,,,, ASH_TMP ,,,,,,, 226年

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

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

SYS@orcl>, insert  into  jingyu.ash_tmp  select  *,得到jingyu.ash_tmp;   SYS@orcl>,提交;      SYS@orcl>, exec  dbms_stats.gather_table_stats(& # 39;宇# 39;& # 39;ASH_TMP& # 39;);      PL/SQL  procedure  successfully 完成。

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

SYS@orcl>, select 所有者,table_name,, num_rows 得到dba_tables  where 所有者=& # 39;宇# 39;;      OWNER ,,,,,, TABLE_NAME ,,,, NUM_ROWS   - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -,- - - - - - - - - - - - - - - - - - - - - - - - - - - - - -,- - - - - - - - - - -   JINGYU ,,,,,, TEST ,,,,,,, 100708   JINGYU ,,,,,, ASH_TMP ,,,,,,, 452年

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

怎么在Oracle中导出导入统计信息