oracle重新收集索引统计信息,ORACLE索引失效,更新统计信息

有时候建立索引的时候不走索引,排除了字段数据问题和sql写法问题之外,应该是统计信息有问题,得重新收集。

一:解锁统计信息

为了稳定执行计划,一般统计信息都会被锁住的,在更新统计信息的时候得先解锁。

①按用户schema解锁:

EXEC DBMS_STATS.UNLOCK_schema_STATS('user_name');

②按表模式解锁:先查出被锁定的表

select table_name from user_tab_statistics where stattype_locked is not null;

然后exec dbms_stats.unlock_table_stats('user_name','表名');

二:收集统计信息方法:

1.分析表

begin

dbms_stats.gather_table_stats (

ownname => 'TEST',tabname => 'STUDENT',estimate_percent => dbms_stats.AUTO_SAMPLE_SIZE,degree => 4,cascade => TRUE);

end;

2.分析用户

begin

dbms_stats.gather_schema_stats(

ownname => 'TEST',cascade => TRUE);

end;

3.分析索引

begin

dbms_stats.gather_index_stats(

ownname => 'TEST',indname => 'IDX_STUDENT_BIRTH',degree => 4);

end;

还可以用analyze 来分析,例如:

ANALYZE TABLE (table_name) COMPUTE STATISTICS; --分析表

ANALYZE TABLE (table_name) COMPUTE STATISTICS FOR ALL INDEXED COLUMNS; --分析索引列

ANALYZE TABLE (table_name) COMPUTE STATISTICS FOR ALL INDEXES FOR ALL COLUMNS; --分析索引和索引列

三:更新完统计信息后得重新锁住。

CALL DBMS_STATS.LOCK_TABLE_STATS('user_name','table_name');

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值