有時候創建索引的時候不走索引,排除了字段數據問題和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');