统计信息的导出导入

常用场景:

1.生产环境的统计信息导入到测试环境使得执行计划的产生能极大程度上等同于生产环境。

2.割接测试环境的统计信息快速导入生产,替代生产库统计信息的收集操作,减少停机时间。

两种方式:

1.expdp/exp STATISTICS,impdp/imp

2.exec dbms_stats.export_schema_stats('SCOTT','STATS_TABLE','SCOTT')/dbms_stats.import_schema_stats

dbms_stats.export_table_stats/dbms_stats.import_table_stats

一般用在割接时间特别紧的时候,快速实现导入替代统计信息的收集操作:大库的收集时间较长。

复制代码
alter session set parallel_force_local=true;
alter session set workarea_size_policy=manual;
alter session set sort_area_size=1073741820;
alter session set sort_area_retained_size=1073741820;
alter session set db_file_multiblock_read_count=128;
exec DBMS_STATS.GATHER_SCHEMA_STATS(ownname=>'OGGSELET',ESTIMATE_PERCENT=>100,method_opt=>'for all columns size 1',cascade=>true,force=>true,degree=>64);

dbms_stats.export_table_stats例子:

生产库和测试库检查:

select TABLE_NAME,COLUMN_NAME,NUM_BUCKETS from DBA_TAB_COL_STATISTICS WHERE TABLE_NAME='DES_SERVICEORDER'

select table_name,num_rows from user_tables where table_name not like 'TEMP%' and table_name not like 'TR_TMP%' and num_rows is null order by table_name

测试库:

创建临时统计表:

exec dbms_stats.create_stat_table(ownname => 'GISTAR',stattab => 'stat_table') ;

=====以下配合生产库的import需反复操作====

truncate table stat_table;

exec dbms_stats.export_table_stats(ownname => 'GISTAR',tabname => 'DES_SERVICEORDER',stattab => 'stat_table');

生产库:

准备tnsnames.ora

oracle@zydb1:/db/product/11.2/db_1/network/admin(lnzy1)>vi tnsnames.ora

LNZYCS2 =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.14.21.36)(PORT = 1521))

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = lnzycs)

)

)

SQL> conn /as sysdba

Connected.

SQL> create public database link gistar_lnzycs2 connect to GISTAR identified by xxx using 'lnzycs2';

Database link created.

SQL> select * from dual@gistar_lnzycs2;

D

X

========以下配合测试库的export反复操作

drop table stat_table;

create table stat_table as select * from stat_table@gistar_lnzycs2;

exec dbms_stats.import_table_stats(ownname => 'GISTAR',tabname => 'DES_SERVICEORDER',stattab => 'stat_table');

其它参考:

dbms_stats 导入导出 schema 级别统计信息-CSDN博客

相关推荐
广州智造1 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
技术宝哥4 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸5 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
dddaidai1236 小时前
Redis解析
数据库·redis·缓存
数据库幼崽6 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd6 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou6 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh7 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵8 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多9 小时前
Linux——mysql主从复制与读写分离
数据库·mysql