Partilhar via


NEXT VALUE FOR (Transact-SQL)

Aplica-se a: SQL Server Banco de Dados SQL do Azure Instância Gerenciada de SQL do Azure

Gera um número de sequência do objeto de sequência especificado.

Para obter uma discussão completa sobre a criação e o uso de sequências, consulte Números de sequência. Use sp_sequence_get_range para gerar e reservar um intervalo de números de sequência.

Convenções de sintaxe de Transact-SQL

Sintaxe

NEXT VALUE FOR [ database_name . ] [ schema_name . ]  sequence_name  
   [ OVER (<over_order_by_clause>) ]  

Argumentos

database_name
O nome do banco de dados que contém o objeto de sequência.

schema_name
O nome do esquema que contém o objeto de sequência.

sequence_name
O nome do objeto de sequência que gera o número.

over_order_by_clause
Determina a ordem na qual o valor da sequência é atribuído às linhas de uma partição. Para obter mais informações, confira Cláusula OVER (Transact-SQL).

Tipos de retorno

Retorna um número usando o tipo da sequência.

Comentários

A função NEXT VALUE FOR pode ser usada em procedimentos armazenados e gatilhos.

Quando a função NEXT VALUE FOR for usada em uma consulta ou restrição padrão, se o mesmo objeto de sequência for usado mais de uma vez ou se o mesmo objeto de sequência for usado na instrução que fornece os valores e em uma restrição padrão em execução, o mesmo valor será retornado para todas as colunas que referenciam a mesma sequência em uma linha no conjunto de resultados.

A função NEXT VALUE FOR é não determinística e apenas é permitida em contextos em que o número de valores de sequência gerados é bem definido. Abaixo está a definição de quantos valores serão usados para cada objeto de sequência referenciado em uma determinada instrução:

  • SELECT – Para cada objeto de sequência referenciado, um novo valor é gerado uma vez por linha no resultado da instrução.

  • INSERT ... VALUES – Para cada objeto de sequência referenciado, um novo valor é gerado uma vez para cada linha inserida na instrução.

  • UPDATE – Para cada objeto de sequência referenciado, um novo valor é gerado para cada linha atualizada pela instrução.

  • Instruções procedurais (como DECLARE, SET, etc.) – Para cada objeto de sequência referenciado, um novo valor é gerado para cada instrução.

Limitações e Restrições

A função NEXT VALUE FOR não pode ser usada nas seguintes situações:

  • Quando um banco de dados está em modo somente leitura.

  • Como um argumento para uma função com valor de tabela.

  • Como um argumento para uma função de agregação.

  • Em subconsultas inclusive expressões de tabela comuns e tabelas derivadas.

  • Em exibições, em funções definidas pelo usuário, ou em colunas computadas.

  • Em uma instrução que usa o operador DISTINCT, UNION, UNION ALL, EXCEPT ou INTERSECT.

  • Em uma instrução que usa a cláusula ORDER BY, a menos que NEXT VALUE FOR ... OVER (ORDER BY ...) seja usado.

  • Nas seguintes cláusulas: FETCH, OVER, OUTPUT, ON, PIVOT, UNPIVOT, GROUP BY, HAVING, COMPUTE, COMPUTE BY ou FOR XML.

  • Em expressões condicionais que usam CASE, CHOOSE, COALESCE, IIF, ISNULL ou NULLIF.

  • Em uma cláusula VALUES que não faz parte de uma instrução INSERT.

  • Na definição de uma restrição de verificação.

  • Na definição de uma regra ou objeto padrão. (Pode ser usado em uma restrição padrão.)

  • Como padrão em um tipo de tabela definido pelo usuário.

  • Em uma instrução que usa TOP, OFFSET ou quando a opção ROWCOUNT é definida.

  • Na cláusula WHERE de uma instrução.

  • Em uma instrução MERGE. (Exceto quando a função NEXT VALUE FOR é usada em uma restrição padrão na tabela de destino e o padrão é usado na instrução CREATE da instrução MERGE.)

Usando um objeto de sequência em uma restrição padrão

Ao usar a função NEXT VALUE FOR em uma restrição padrão, as seguintes regras se aplicam:

  • Um único objeto de sequência pode ser referenciado de restrições padrão em várias tabelas.

  • A tabela e o objeto de sequência devem residir no mesmo banco de dados.

  • O usuário que adiciona a restrição padrão deve ter permissão de REFERENCES no objeto de sequência.

  • Um objeto de sequência que é referenciado de uma restrição padrão não pode ser removido antes da restrição padrão ser removida.

  • A mesma sequência de número é retornada para todas as colunas em uma linha se diversas restrições padrão usam o mesmo objeto de sequência, ou se o mesmo objeto de sequência for usado na instrução que fornece os valores, e em uma restrição padrão que é executada.

  • As referências à função NEXT VALUE FOR em uma restrição padrão não podem especificar a cláusula OVER.

  • Um objeto de sequência referenciado em uma restrição padrão pode ser alterado.

  • No caso de uma instrução INSERT ... SELECT ou INSERT ... EXEC em que os dados inseridos são obtidos de uma consulta que usa uma cláusula ORDER BY, os valores retornados pela função NEXT VALUE FOR serão gerados na ordem especificada pela cláusula ORDER BY.

Usando um objeto de sequência com uma cláusula OVER ORDER BY

A função NEXT VALUE FOR é compatível com a geração de valores de sequência classificados com a aplicação da cláusula OVER à chamada NEXT VALUE FOR. Usando a cláusula OVER, um usuário tem a garantia de que os valores retornados são gerados na ordem da subcláusula ORDER BY da cláusula OVER. As seguintes regras adicionais aplicam-se ao usar a função NEXT VALUE FOR com a cláusula OVER:

  • Diversas chamadas à função NEXT VALUE FOR para o mesmo gerador de sequência em uma única instrução devem todas usar a mesma definição de cláusula OVER.

  • Diversas chamadas à função NEXT VALUE FOR que referenciam diferentes geradores de sequência em uma única instrução podem ter diferentes definições de cláusula OVER.

  • Uma cláusula OVER aplicada à função NEXT VALUE FOR não dá suporte à subcláusula PARTITION BY.

  • Se todas as chamadas à função NEXT VALUE FOR em uma instrução SELECT especificarem a cláusula OVER, uma cláusula ORDER BY poderá ser usada na instrução SELECT.

  • A cláusula OVER é permitida com a função NEXT VALUE FOR quando usada em uma instrução SELECT ou INSERT ... SELECT .... O uso da cláusula OVER com a função NEXT VALUE FOR não é permitido em instruções UPDATE ou MERGE.

  • Se outro processo estiver acessando o objeto de sequência ao mesmo tempo, os números retornados poderão ter intervalos.

Metadados

Para obter informações sobre sequências, consulte a exibição do catálogo sys.sequences.

Segurança

Permissões

Exige a permissão UPDATE no objeto de sequência ou o esquema da sequência. Para obter um exemplo de concessão de permissão, consulte o exemplo F posteriormente neste tópico.

Encadeamento de propriedade

Objetos de sequência oferecem suporte a encadeamento de propriedade. Se o objeto de sequência tiver o mesmo proprietário que o procedimento armazenado de chamada, gatilho ou tabela (tendo um objeto de sequência como uma restrição padrão), nenhuma verificação de permissão será exigida no objeto de sequência. Se o objeto de sequência não tiver o mesmo proprietário que o procedimento armazenado de chamada, gatilho ou tabela, uma verificação de permissão será exigida no objeto de sequência.

Quando a função NEXT VALUE FOR é usada como um valor padrão em uma tabela, os usuários precisam das permissões INSERT na tabela e UPDATE no objeto de sequência para inserir dados usando o padrão.

  • Se a restrição padrão tiver o mesmo proprietário que o objeto de sequência, nenhuma permissão será exigida no objeto de sequência quando a restrição padrão for chamada.

  • Se a restrição padrão e o objeto de sequência não tiverem o mesmo proprietário, as permissões serão exigidas no objeto de sequência mesmo que seja chamada através de uma restrição padrão.

Audit

Para auditar a função NEXT VALUE FOR, monitore o SCHEMA_OBJECT_ACCESS_GROUP.

Exemplos

Para obter exemplos de como criar sequências e usar a função NEXT VALUE FOR para gerar números de sequência, consulte Números de sequência.

Os exemplos a seguir usam uma sequência chamada CountBy1 em um esquema chamado Test. Execute a seguinte instrução para criar a sequência Test.CountBy1. Os exemplos C e E usam o banco de dados AdventureWorks2022, portanto, a sequência CountBy1 é criada naquele banco de dados.

USE AdventureWorks2022;  
GO  
  
CREATE SCHEMA Test;  
GO  
  
CREATE SEQUENCE Test.CountBy1  
    START WITH 1  
    INCREMENT BY 1 ;  
GO  

a. Usando uma sequência em uma instrução select

O exemplo a seguir cria uma sequência chamada CountBy1, que aumenta em incrementos de um cada vez que é utilizada.

SELECT NEXT VALUE FOR Test.CountBy1 AS FirstUse;  
SELECT NEXT VALUE FOR Test.CountBy1 AS SecondUse;  

Veja a seguir o conjunto de resultados.

FirstUse  
1  
 
SecondUse  
2

B. Definindo uma variável como o próximo valor de sequência

O exemplo a seguir demonstra três modos de definir uma variável como o próximo valor de um número de sequência.

DECLARE @myvar1 BIGINT = NEXT VALUE FOR Test.CountBy1  
DECLARE @myvar2 BIGINT ;  
DECLARE @myvar3 BIGINT ;  
SET @myvar2 = NEXT VALUE FOR Test.CountBy1 ;  
SELECT @myvar3 = NEXT VALUE FOR Test.CountBy1 ;  
SELECT @myvar1 AS myvar1, @myvar2 AS myvar2, @myvar3 AS myvar3 ;  
GO  

C. Usando uma sequência com uma função de janela de classificação

USE AdventureWorks2022;  
GO  
  
SELECT NEXT VALUE FOR Test.CountBy1 OVER (ORDER BY LastName) AS ListNumber,  
    FirstName, LastName  
FROM Person.Contact ;  
GO  

D. Usando a função NEXT VALUE FOR na definição de uma restrição padrão

Há compatibilidade com o uso da função NEXT VALUE FOR na definição de uma restrição padrão. Para obter um exemplo de como usar NEXT VALUE FOR em uma instrução CREATE TABLE, veja o exemplo C em Números de sequência. O exemplo a seguir usa ALTER TABLE para adicionar uma sequência como um padrão em uma tabela atual.

CREATE TABLE Test.MyTable  
(  
    IDColumn NVARCHAR(25) PRIMARY KEY,  
    name VARCHAR(25) NOT NULL  
) ;  
GO  
  
CREATE SEQUENCE Test.CounterSeq  
    AS INT  
    START WITH 1  
    INCREMENT BY 1 ;  
GO  
  
ALTER TABLE Test.MyTable  
    ADD   
        DEFAULT N'AdvWorks_' +   
        CAST(NEXT VALUE FOR Test.CounterSeq AS NVARCHAR(20))   
        FOR IDColumn;  
GO  
  
INSERT Test.MyTable (name)  
VALUES ('Larry') ;  
GO  
  
SELECT * FROM Test.MyTable;  
GO  

E. Usando uma função NEXT VALUE FOR em uma instrução INSERT

O exemplo a seguir cria uma tabela chamada TestTable e usa a função NEXT VALUE FOR para inserir uma linha.

CREATE TABLE Test.TestTable  
     (CounterColumn INT PRIMARY KEY,  
    Name NVARCHAR(25) NOT NULL) ;   
GO  
  
INSERT Test.TestTable (CounterColumn,Name)  
    VALUES (NEXT VALUE FOR Test.CountBy1, 'Syed') ;  
GO  
  
SELECT * FROM Test.TestTable;   
GO  

E. Usando a função NEXT VALUE FOR com SELECT ... INTO

O exemplo a seguir usa a instrução SELECT ... INTO para criar uma tabela chamada Production.NewLocation e usa a função NEXT VALUE FOR para numerar cada linha.

USE AdventureWorks2022;   
GO  
  
SELECT NEXT VALUE FOR Test.CountBy1 AS LocNumber, Name   
    INTO Production.NewLocation  
    FROM Production.Location ;  
GO  
  
SELECT * FROM Production.NewLocation ;  
GO  

F. Concedendo permissão para executar NEXT VALUE FOR

O exemplo a seguir concede a permissão UPDATE a uma permissão AdventureWorks\Larry nomeada pelo usuário para executar NEXT VALUE FOR usando a sequência Test.CounterSeq.

GRANT UPDATE ON OBJECT::Test.CounterSeq TO [AdventureWorks\Larry] ;  

Consulte Também

CREATE SEQUENCE (Transact-SQL)
ALTER SEQUENCE (Transact-SQL)
Números de sequência