• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Oracle统计信息的导出导入测试示例详解

    背景:

    有时我们会希望可以对Oracle的统计信息整体进行导出导入。比如在数据库迁移前后,希望统计信息保持不变;又比如想对统计信息重新进行收集,但是担心重新收集的结果反而引发性能问题,想先保存当前的统计信息,这样即使重新收集后效果不好还可以导入之前的统计信息。

    Oracle提供给我们一些方法,比较常用的粒度有两种:

    统计信息存放的表可以通过DBMS_STATS.CREATE_STAT_TABLE和DBMS_STATS.DROP_STAT_TABLE来进行创建或是删除。

    1.示例schema级别统计信息的导出导入

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

    --源端统计信息导出:
    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级别统计信息的导出导入

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

    --源端统计信息导出:
    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用户下各表在统计信息记录数:

    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> 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.

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

    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

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

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

    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

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

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

    总结

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

    您可能感兴趣的文章:
    • JDBC Oracle执行executeUpdate卡死问题的解决方案
    • ORACLE检查找出损坏索引(Corrupt Indexes)的方法详解
    • Oracle call 和 exec的详解及区别
    • Oracle数据库中 call 和 exec的区别
    • Oracle基础:通过sqlplus执行sql语句后的结果进行判断
    • Oracle数据库自动备份脚本分享(超实用)
    • VMware下CentOS静默安装oracle12.2详细图文教程
    • ORACLE中关于表的一些特殊查询语句
    • ORACLE中查找定位表最后DML操作的时间小结
    • 运行在容器中的Oracle XE-11g
    上一篇:Oracle数据库自动备份脚本分享(超实用)
    下一篇:Oracle基础:通过sqlplus执行sql语句后的结果进行判断
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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