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

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

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重新统计数据的统计信息。

相关推荐
哈__12 分钟前
MongoDB 平替新方案:金仓多模数据库驱动电子证照国产化落地
数据库·1024程序员节
微学AI1 小时前
国产数据库替代MongoDB的技术实践过程:金仓多模数据库在电子证照系统中的深度应用
数据库·人工智能·1024程序员节
TDengine (老段)1 小时前
TDengine 数据函数 ROUND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·1024程序员节
TDengine (老段)1 小时前
TDengine 数学函数 RAND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
野犬寒鸦1 小时前
从零起步学习MySQL || 第十章:深入了解B+树及B+树的性能优势(结合底层数据结构与数据库设计深度解析)
java·数据库·后端·mysql·1024程序员节
GZ_TOGOGO1 小时前
Oracle OCP考试报名常见问题详解
数据库·oracle·ocp认证
睡不醒的猪儿1 小时前
nginx日志同步阿里云datahub后写入数据库
数据库·nginx·阿里云
xie_zhr2 小时前
【PB案例学习笔记】-46在数据窗口中编辑数据
数据库·his·1024程序员节·干货分享·pb·powerbuilder
小小的木头人2 小时前
Redis 集群安装指南
数据库·redis
星空的资源小屋2 小时前
Antares SQL,一款跨平台开源 SQL 客户端
数据库·人工智能·pdf·开源·电脑·excel·1024程序员节