千家信息网

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

发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,怎么在Oracle中导出导入统计信息?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。schema级别统计信息的导出导入通过调用DBMS
千家信息网最后更新 2025年11月08日怎么在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下所有的统计信息进行导出导入:

--源端统计信息导出: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=nexec 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=nexec 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        100708JINGYU       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        100708JINGYU       ASH_TMP        452

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

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

SYS@orcl> select owner, table_name, num_rows from dba_tables where owner='JINGYU';OWNER       TABLE_NAME      NUM_ROWS------------------------------ ------------------------------ ----------JINGYU       TEST        100708JINGYU       ASH_TMP        226SYS@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');

关于怎么在Oracle中导出导入统计信息问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注行业资讯频道了解更多相关知识。

信息 统计 数据 数据库 级别 步骤 实际 目标 问题 中导 效果 方法 更多 环境 示例 选择性 帮助 查询 解答 选择 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 凤凰系统数据库 计算机网络安全与直播应用 辽宁潮流软件开发标准 军队网络安全资质 数据库的软件技术 公安局网络安全中心是什么单位 主流 软件开发 平台 没有基础学习软件开发 WIN10 数据库共享 上海储物柜软件开发 数据库安装方式有几种 河南维托网络技术有限公司 网络技术软件与应用技术类 公司需要养着一个软件开发团队吗 生物医学数据库 电源12伏18a能带动服务器吗 林溉脖网络技术有限公司 蓝牙设备怎么连接终端数据库 通辽市网络安全应急管理中心 榆林到凤翔高速路上有哪些服务器 上海工程软件开发公司 云服务器试玩游戏赚钱 服务器远程不上 请简述数据库可采取的安全措施 国家采取措施监督预防网络安全 河南维托网络技术有限公司 我国大范围的dna数据库 新乡天泽网络技术工作室 入侵网站拿服务器 文件路径怎么设置服务器
0