ORACLE索引失效,更新統計信息

有時候創建索引的時候不走索引,排除了字段數據問題和sql寫法問題,索引失效的問題以外,還得考慮是統計信息過舊,得從新收集。
  查看錶的統計信息,看 user_index 的last_analyze(索引),
    看user_tab_col_statistics 的last_analyze(字段)

一:解鎖統計信息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','表名');

二:收集統計信息方法:ide

1.分析表code

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',

estimate_percent => dbms_stats.AUTO_SAMPLE_SIZE,

degree           => 4,

cascade          => TRUE);

end;

3.分析索引it

begin

    dbms_stats.gather_index_stats(

    ownname          => 'TEST',

    indname          => 'IDX_STUDENT_BIRTH',

    estimate_percent => dbms_stats.AUTO_SAMPLE_SIZE,

    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');
相關文章
相關標籤/搜索