SQL Server Performance

Como esconder a mensagem de números de linhas afetado – SET NOCOUNT

SQL Server Performance

Saiba como esconder a mensagem de números de linhas afetado SET NOCOUNT

Muitas transações no SQL Server quando terminam retornam uma mensagem de quantas linhas foram impactadas naquela transação. Essa informação é boa quando você quer saber quantas linhas foram afetadas na execução de uma procedure por exemplo, ou um script simples executado no SQL Server. Entretanto se você não precisa saber sobre essa informação, acaba sendo uma coisa inútil. Eu tenho observado em vários casos que tenho atuado, onde programadores não usam essa opção em suas procedures causando impacto na performance, principalmente no tráfico de rede.
Em resumo, se você não precisa saber quantas linhas foram impactadas na transação que foi executada, basta desativar a função utilizando SET NOCOUNT ON isso vai reduzir o tráfego na rede proporcionando melhor performance.
Aqui temos um exemplo, basta rodar o comando SET NOCOUNT ON uma vez que será ativado até que a sessão seja fechada, esse comando vale apenas para a sessão que está aberta, para visualizar os resultados novamente basta ativar SET NOCOUNT OFF.

Teste: SET NOCOUNT ON 

SET NOCOUNT ON
-- Demo Code
CREATE TABLE #Temp1 (ID BIGINT)
DECLARE @Var BIGINT
SET @Var = 1000
WHILE(@Var > 0)
BEGIN
INSERT INTO #Temp1 (ID)
VALUES (@Var)
SET @Var = @Var -1
END
DROP TABLE #Temp1;

Se desabilitar essa opção, veremos como os resultados aparecem

SET NOCOUNT ON

Se habilitar novamente para a opção padrão SET NOCOUNT OFF, podemos ver que as quantidades de linhas afetadas somem.

SETNOCOUNTOFF

Como esconder a mensagem de números de linhas afetado – SET NOCOUNT
The following two tabs change content below.

Wesley Mota

DBA SQL Server
Profissional graduado em Banco de Dados e Sistemas de Informação com mais de 7 anos de experiência em empresas de software. Certificado MCSA Microsoft SQL Server possui intensa vivência em administração de banco de dados, Tunning, Performance SQL Server, levantamento de melhorias e monitoramento de banco de dados e servidores SQL Server. Consultoria SQL Server em diversos clientes no Brasil e ao redor do mundo. Escritor no blog dbasqlserverbr.com.br/blog. Onde compartilha conhecimento, experiências e dicas de performance para DBAs SQL Server. Conhecimentos em Oracle e ambientes de alta disponibilidade. Desenvolvimento de softwares web e mobile.Gerenciamento de equipe e projetos.

Latest posts by Wesley Mota (see all)