时间:2021-05-24
背景:
有时我们会希望可以对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=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');再尝试导入统计信息就可以成功了。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
oracle如何导入导出表在数据库中导出表后导入,是一个完整的操作,内容中的oracle11g是安装在windows上的。oracle的imp/exp就相当于o
oracle导入导出数据1.导出dmp格式文件--备份某几张表!!!!expsmsc/smscfile=/data/oracle_bak/dmp/bakup02
主要讲四个示例的使用:导出(out),导入(in),查询导出(queryout),导出格式化(-f)文件。示例1:导出示例数据库AdventureWorks整个
oracle提供了sqlldr的工具,有时需要讲数据导入到文本,oracle的spool可以轻松实现。方便的实现oracle导出数据到txt、txt导入数据到o
oracle数据库数据导入导出步骤(入门)说明:1.数据库数据导入导出方法有多种,可以通过exp/imp命令导入导出,也可以用第三方工具导出,如:PLSQL2.