Uma tabela com um único índice já monta uma estatística que indica qual a distribuição
espacial dos dados organizados pelo índice. Se a tabela possui vários índices o firebird utiliza
as estatísticas para escolher os melhores índices para responder a solicitação do usuário.
Sempre que é feito INSERT, UPDATE em uma coluna que pertence a um índice, o índice é
atualizado, mas sua estatítica não segue a mesma mecânica (ocorre uma espécie de
fragmentação do índice).
Se o firebird decide com base na estatítica do índice, não é difícil imaginar que com a
fragmentação o que deveria ser um benefício passa a ser um problema.
Então o firebird recomenda que depois de algum tempo – as estatísticas do banco de dados
sejam refeitas para refletir com melhor precisão a situação do índice.
Para facilitar este trabalho, segue uma procedure que força a atualização dos índice de todas
as suas tabelas.
SET TERM ^ ; CREATE OR ALTER PROCEDURE REINDEX as declare variable sql varchar(255); begin for select rdb$index_name from rdb$indices into :sql do begin sql = 'SET STATISTICS INDEX ' || sql; execute statement :sql; end end^ SET TERM ; ^ GRANT EXECUTE ON PROCEDURE REINDEX TO SYSDBA;