Ask Learn
Preview
Ask Learn is an AI assistant that can answer questions, clarify concepts, and define terms using trusted Microsoft documentation.
Please sign in to use Ask Learn.
Sign inThis browser is no longer supported.
Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.
Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Pode parecer uma dica simples demais, mas tenho observado muitas dúvidas quanto ao uso do NOLOCK. No tempo do SQL 2000, a própria Microsoft (que ninguém me ouça dizendo isso!) recomendava o uso indiscriminado do NOLOCK [sem referência]. Por esse motivo, decidi explicar um pouco seu funcionamento.
Conhece o checklist de Performance de servidor?
SQL Server utiliza mecanismos de bloqueio (LOCK) para garantir a integridade de dados. O fato é que muitas vezes o bloqueio (LOCK) impacta diretamente na performance do sistema. Por exemplo, veja os dois comandos:
1) SELECT COUNT(Nome) FROM TabelaPessoas
2) INSERT TabelaPessoas (Nome) VALUES ('Fabricio')`
Se forem executados simultaneamente, os comandos efetuarão leitura (SELECT) e escrita (INSERT) contra a mesma tabela. Entretanto, o banco de dados garante a integridade e executa um comando por vez. Em outras palavras, o comando de SELECT não pode ocorrer no mesmo instante que o INSERT. Esse é um caso simples e inofensivo, mas pense agora nos sistemas de grande porte.
Um banco de dados que precisa executar 100 transações por segundo, mas precisa gerar alguns relatórios rápidos. As transações correspondem aos INSERTS, enquanto que os relatórios são SELECT. Como podemos melhorar a performance dos INSERT que concorrem com comandos SELECT?
O comando SELECT permite o uso de uma opção denominada NOLOCK, evitando assim os bloqueios com os comandos de INSERT. O uso é simples, bastando adicionar algumas palavras após a declaração da tabela.
SELECT COUNT(Nome) FROM TabelaPessoas WITH (NOLOCK)
Dessa forma, o comando WITH (NOLOCK) indica que não será necessário bloquear a tabela durante a leitura dos dados.
O uso de NOLOCK indiscrinado pode causar problemas transitórios devido a movimentação de dados sem bloqueios. Veja os exemplos Efeitos colaterais do NOLOCK – Parte I e Efeitos colaterais do NOLOCK – Parte 2.
A partir do SQL Server 2005/2008, existe uma solução mais elegante que é o uso do READ COMMITTED SNAPSHOT no banco de dados. O melhor de tudo é que essa é uma configuração do banco de dados e não necessita alteração em código.
Links relacionados
Anonymous
October 06, 2010
Já tivemos muitos problemas de lock no passado aqui na empresa, hoje usamos muito nolock...
Preciso estudar melhor o READ COMMITTED SNAPSHOT, para ver se podemos implementar.
Muito bom post, me fez reviver este assunto na mente.
Parabéns.
Anonymous
October 06, 2010
Obrigado! Se tiver sugestões sobre como deveria ser o post sobre READ COMMITTED SNAPSHOT, avise!
Abraços, Fabricio
Anonymous
November 30, 2010
Fabricio, boa tarde.
Eu vejo em muitos artigos sobre o isolation level das bases de dados, mas, como e feita a configuração para que o banco de dados use o READ COMMITED SNAPSHOT?
SET BancoDeDados IsolationLevel?
Abs
Anonymous
November 30, 2010
A configuração é feita por banco de dados usando o comando:
ALTER DATABASE <nome_do_banco) SET READ_COMMITTED_SNAPSHOT ON
Acho que faltou explicar isso melhor, né?
Abraços, Fabricio
Anonymous
April 18, 2011
Vale lembrar que o uso do RCSI aumenta também o uso de TempDB. Só dar aquela verificada se a TemDB está seguindo as recomendações de multiplo arquivos e se há espaço suficiente.
Em aplicações como Dynamics CRM, o uso do RCSI auxiília bastante na performance do sistema.
Anonymous
July 17, 2014
Mas um alerta sobre o With (NOLOCK), cuidado com as Leituras Suja e Fantasma. NOLOCK permite que você leia dados que não foram Commitados.
Anonymous
January 20, 2015
Boa tarde.
Realmente o uso do (NOLOCK) é fundamental, parabéns pelo post....
Anonymous
January 21, 2015
NOLOCK deixa selects mais rapidos ?
Anonymous
January 28, 2015
Sim, NOLOCK ajuda em desempenho - em contrapartida, os dados são lidos "sujos".
Anonymous
September 14, 2015
Pra Evitar os dados sujos
with (readpast)
Anonymous
March 08, 2016
Muito bom ajudou bastante, estou com um problema em uma query, e a mesma possui varios nolock resolvi deixar onde faz inserte e updade
Anonymous
July 28, 2016
O ideal seria se a Microsoft mudasse para o snapshot isolation level como sendo padrão do SQL Server. Acho que assim, evitaria-se o problema de leitura suja.
Ask Learn is an AI assistant that can answer questions, clarify concepts, and define terms using trusted Microsoft documentation.
Please sign in to use Ask Learn.
Sign in