Create Index não é Tuning II
Esse post é dedicado a um grande amigo que me ensinou muito sobre Tuning e Performance um dos melhores DBAs que conheci, Sergio Bonsague.
Esse artigo é continuação do último post lançado aqui no blog. A coisa mais divertida no SQL Server é saber, porque ele fez isso ou aquilo? Por que “tal” decisão foi tomada, entender um pouco desse mundo obscuro…rs. Vamos parar de tagarelar e colocar a mão na massa.
Se analisarmos o plano de execução do post print, o SQL Server escolheu utilizar um Clustered Index Seek para ler toda a tabela. Porém, fica a pergunta, Ele não poderia ter escolhido um Clustered Index Scan? Como vou ler tudo, um Scan não é melhor que um Seek? A resposta é: Depende.
Executando duas vezes a mesma query, uma com o HINT WITH(INDEX=0) que força a Não utiliza do Index da tabela e uma sem utilização de hint, para que possamos comparar o antes e depois.
Executando a query forçando um Clustered Index Scan Vs um Clustered Index Seek podemos ver que no plano de execução o custo de ambos é de 50% (Atual e Estimado).
Thiago, que dizer que é a mesma coisa? A resposta é não. Quando se está avaliando performance, o ideal também é utilizar como parâmetro os tempos de execução, para isso sempre uso o Profiler. A quantidade de leitura é muito menor quando utilizamos um Clustered Index Seek, Vejamos o resultado:
O SQL Server realizou uma quantidade menor de leituras utilizando o Index Seek. Mas, porque?
No Seek temos duas propriedades que não aparecem no Scan que no caso é a “Direção da Leitura”, como pode ser visto utiliza o “FORWARD” e está marcada como “ORDERED” como True.
Já o Clustered Index Scan, essas propriedades não são apresentadas. É a única questão que acredito ser o motivo.
Esperam que vocês tenham gostado.
3 comentários
[…] Create Index não é Tuning II! […]
Show de bola, é ótimo saber que tem alguém que entra no “Mundo Obscuro” do MS SQL Server e consegue nos passar a informação com facilidade. Uma coisa que aprendi com Thiago Alencar é que tudo no SQL Server precisa ser bem analisada, pois existem N variáveis que podem mudar uma resposta que antes parecia ser “obvia”.
Ótimo post Thiago. Continue assim.
Abraços Felipe Subtil
Eh disso que eu estou falando