重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2256|回复: 0
打印 上一主题 下一主题

[转载] 【统计信息】如何备份和还原统计信息

[复制链接]
跳转到指定楼层
楼主
发表于 2021-1-7 11:29:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 jiawang 于 2021-1-7 18:30 编辑

一、介绍
备份和还原统计信息,是指利用存储过程创建一个模板表,将存储信息存储在模板表内。如果需要还原,则将模板表内的统计信息导出还原即可。
二、备份统计信息1.用户创建一个“统计信息表”

SQL> conn test_user/oracle
SQL> exec dbms_stats.create_stat_table('TEST_USER','STAT_TIMESTAMP');


2.传输统计信息到“统计信息表”
1)传输多表的统计信息到“统计信息表”
SQL> exec dbms_stats.export_table_stats(user,'TAB1',NULL,'STAT_TIMESTAMP');
SQL> exec dbms_stats.export_table_stats(user,'TAB2',NULL,'STAT_TIMESTAMP');
SQL> exec dbms_stats.export_table_stats(user,'TAB3',NULL,'STAT_TIMESTAMP');


2)传输整个schemas的统计信息
SQL> exec dbms_stats.export_schema_stats(user,'STAT_TIMESTAMP');

3)传输system统计信息到“统计信息表”
-- 检查system状态
SQL> select sname,pname,pval1 from sys.aux_stats$ where pval1 is not null;
-- 创建统计信息表
SQL> exec dbms_stats.create_stat_table(user,'STAT_TIMESTAMP');
-- 导出
SQL> exec dbms_stats.export_system_stats('STAT_TIMESTAMP');
-- 导入
SQL> exec dbms_stats.import_system_stats('STAT_TIMESTAMP');


3.还原统计信息

1)还原某个表的统计信息
SQL> exec dbms_stats.import_table_stats(NULL,'TAB1', NULL,'STAT_TIMESTAMP');
SQL> exec dbms_stats.import_table_stats(NULL,'TAB2', NULL,'STAT_TIMESTAMP');
SQL> exec dbms_stats.import_table_stats(NULL,'TAB3', NULL,'STAT_TIMESTAMP');

4.查询存储在STAT_TIMESTAMP表中的统计信息
SQL> select distinct c1 from STAT_TIMESTAMP where type ='T';
C1
------------------------------
TAB2
TAB1
TAB3
上面结果显示,在表STAT_TIMESTAMP中,存着TAB1,TAB2,TAB3三个表的统计信息。


5.还原所有表的统计信息
SQL> exec dbms_stats.import_schema_stats(user,'STAT_TIMESTAMP');

---- end ----

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-4-20 06:50 , Processed in 0.098586 second(s), 20 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表