表、索引统计信息锁定和解锁

零、查看数据库的统计信息收集是否开启

select * from dba_autotask_client;

auto optimizer stats collection 是表示开启数据库自动统计信息收集。

一、查看统计信息是否锁定

select stattype_locked,last_analyzed,a.* from dba_tab_statistics a where a.stattype_locked is not null;

该字段值为空表示 没有锁定,ALL则表示统计信息收集被锁定。

二、解锁、统计信息收集、锁定

exec dbms_stats.unlock_table_stats(ownname => 'USER1',tabname => 'TABLE1');

exec dbms_stats.gather_table_stats('USER1','TABLE1');

exec dbms_stats.lock_table_stats('USER1','TABLE1');

三、其他

--analyze命令已经过时

-- 无法提供灵活的分析选项

-- 无法提供并行的分析

-- 无法对分析数据进行管理

--DBMS_STATS

-- 专门为CBO提供信息来源

-- 可以进行数据分析的多种组合

-- 可以对分区进行分析

-- 可以进行分析数据管理

• 备份,恢复,删除,设置....

不能收集行迁移,行迁移需要使用analyze

analyze table productuser.supplymessage validate structure cascade;

--创建统计信息历史保留表

begin

dbms_stats.create_stat_table(ownname => 'productuser',stattab => 'stat_tableofproduct') ;

end;

--导出整个scheme的统计信息

begin

dbms_stats.export_schema_stats(ownname => 'productuser',stattab => 'stat_tableofproduct') ;

end;

--删除表的统计信息

begin

dbms_stats.delete_table_stats(ownname => 'productuser',tabname => 'product') ;

end;

select * from user_tables where table_name='PRODUCT'

--导入表的历史统计信息

begin

dbms_stats.import_table_stats(ownname => 'productuser',tabname => 'product',stattab => 'stat_tableofproduct') ;

end;

--如果进行分析后,大部分表的执行计划都走错,需要导回整个scheme的统计信息

begin

dbms_stats.import_schema_stats(ownname => 'productuser',stattab => 'stat_tableofproduct');

end;

--导入索引的统计信息

begin

dbms_stats.import_index_stats(ownname => 'productuser',indname => 'xxx',stattab => 'stat_tableofproduct')

end;

analyze table 可以指定分析: 表、所有字段、所有索引字段、所有索引。 若不指定则全部都分析。

1、全分析

说明:全分析,包括表、字段、索引。统计信息产生在user_tables、user_tab_columns、user_indexes中。

analyze table my_table compute statistics for table for all indexes for all columns;

2、指定表分析

说明:只分析表。统计信息只产生在user_tables中。

analyze table my_table compute statistics for table;

查看表的统计信息:select table_name,num_rows,blocks,empty_blocks from user_table;

3、指定所有字段分析

说明:只分析字段。统计信息只产生在user_tab_columns中,且全字段有。

analyze table my_table compute statistics for all columns;

查看字段的统计信息:select table_name,column_name,num_distinct,low_value,high_value,density from user_tab_columns;

4、指定有索引的字段分析

说明:只分析有索引的字段。统计信息只产生在user_tab_columns中,且只有含索引的字段有。

analyze table my_table compute statistics for all indexed columns;

5、指定索引分析

说明:只分析索引。统计信息只产生在user_indexes中。

analyze table my_table compute statistics for all indexes;

查看索引的统计信息

select table_name,index_name,blevel,leaf_blocks,distinct_keys,avg_leaf_blocks_per_key,avg_data_blocks_per_key,clustering_factor,num_rows from user_indexes;

另外,可以删除分析数据:

SQL> analyze table my_table delete statistics;

SQL> analyze table my_table delete statistics for table for all indexes for all indexed columns;

特别需要注意的:

truncate命令不会修改数据的统计信息,也就是如果我们想让CBO利用合理利用数据的统计信息的时候,需要我们及时的使用analyze命令或者dbms_stats重新统计数据的统计信息。

相关推荐
小马学嵌入式~7 分钟前
嵌入式 SQLite 数据库开发笔记
linux·c语言·数据库·笔记·sql·学习·sqlite
Java小白程序员29 分钟前
MyBatis基础到高级实践:全方位指南(中)
数据库·mybatis
Monly2135 分钟前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql
不宕机的小马达1 小时前
【Mysql|第一篇】Mysql的安装与卸载、Navicat工具的使用
数据库·mysql
float_六七1 小时前
数据库连接池:性能优化的秘密武器
数据库·oracle·性能优化
码界奇点1 小时前
MongoDB vs MySQLNoSQL与SQL数据库的架构差异与选型指南
数据库·sql·mongodb·系统架构
IT 小阿姨(数据库)1 小时前
PgSQL中pg_stat_user_tables 和 pg_stat_user_objects参数详解
linux·运维·数据库·sql·postgresql·oracle
倔强的石头_1 小时前
Windows系统下KingbaseES数据库保姆级安装教程(附常见问题解决)
数据库
麦兜*2 小时前
MongoDB 常见错误解决方案:从连接失败到主从同步问题
java·数据库·spring boot·redis·mongodb·容器
RestCloud2 小时前
PostgreSQL大表同步优化:如何避免网络和内存瓶颈?
前端·数据库·api