SET ROWCOUNT (Transact-SQL)
Aplica-se a: SQL Server Banco de Dados SQL do Azure Instância Gerenciada de SQL do Azure PDW (Sistema de Plataforma de Análise) do Azure Synapse Analytics
Faz o SQL Server parar o processamento da consulta depois que o número especificado de linhas for retornado.
Convenções de sintaxe de Transact-SQL
Sintaxe
SET ROWCOUNT { number | @number_var }
Observação
Para exibir a sintaxe do Transact-SQL para o SQL Server 2014 (12.x) e versões anteriores, confira a Documentação das versões anteriores.
Argumentos
number | @number_var
É o número inteiro de filas a serem processadas antes de finalizar a consulta específica.
Comentários
Importante
O uso de SET ROWCOUNT não afetará as instruções DELETE, INSERT e UPDATE em uma futura versão do SQL Server. Evite usar SET ROWCOUNT com instruções DELETE, INSERT e UPDATE em um novo trabalho de desenvolvimento e planeje modificar os aplicativos que a utilizam atualmente. Para um comportamento semelhante, use a sintaxe de TOP. Para saber mais, confira TOP (Transact-SQL).
Para desligar esta opção de forma que todas as linhas sejam retornadas, especifique SET ROWCOUNT 0.
A configuração da opção SET ROWCOUNT faz com que a maioria das instruções Transact-SQL parem de processar quando forem afetadas pelo número de linhas especificado. Isso inclui gatilhos. A opção ROWCOUNT não afeta cursores dinâmicos, mas limita o conjunto de linhas de conjunto de chaves e cursores sem distinção. Essa opção deve ser usada com cuidado.
SET ROWCOUNT substituirá a palavra-chave TOP da instrução SELECT TOP se o número de linhas for o menor valor.
A configuração de SET ROWCOUNT é definida no momento da execução ou em tempo de execução e não no momento da análise.
Permissões
Requer associação à função public.
Exemplos
SET ROWCOUNT para de processar depois do número especificado de linhas. No exemplo a seguir, observe que mais de 500 linhas atendem aos critérios de Quantity
menor que 300
. Porém, depois de aplicar SET ROWCOUNT, você pode ver que nem todas as linhas foram retornadas.
USE AdventureWorks2022;
GO
SELECT count(*) AS Count
FROM Production.ProductInventory
WHERE Quantity < 300;
GO
Este é o conjunto de resultados.
Count
-----------
537
(1 row(s) affected)
Agora, defina ROWCOUNT
como 4
e retorne todas as linhas para demonstrar que apenas quatro linhas são retornadas.
SET ROWCOUNT 4;
SELECT *
FROM Production.ProductInventory
WHERE Quantity < 300;
GO
-- (4 row(s) affected)
Exemplos: Azure Synapse Analytics e PDW (Analytics Platform System)
SET ROWCOUNT para de processar depois do número especificado de linhas. No exemplo a seguir, observe que mais de 20 linhas atendem aos critérios de AccountType = 'Assets'
. Porém, depois de aplicar SET ROWCOUNT, você pode ver que nem todas as linhas foram retornadas.
-- Uses AdventureWorks
SET ROWCOUNT 5;
SELECT * FROM [dbo].[DimAccount]
WHERE AccountType = 'Assets';
Para retornar todas as linhas, defina ROWCOUNT como 0.
-- Uses AdventureWorks
SET ROWCOUNT 0;
SELECT * FROM [dbo].[DimAccount]
WHERE AccountType = 'Assets';