Compartilhar via


BEGIN...END (Transact-SQL)

Abrange uma série de instruções Transact-SQL para que um grupo de instruções Transact-SQL possa ser executado. BEGIN e END são palavras-chave da linguagem de controle de fluxo.

Aplica-se a: SQL Server (SQL Server 2008 até a versão atual), Banco de dados SQL do Windows Azure (versão inicial até a versão atual).

Ícone de vínculo de tópico Convenções da sintaxe Transact-SQL

Sintaxe

BEGIN
     { 
    sql_statement | statement_block 
     } 
END

Argumentos

  • { sql_statement| statement_block }
    É qualquer instrução ou agrupamento de instruções Transact-SQL válido, como definido com o uso de um bloco de instrução.

Comentários

Os blocos BEGIN...END podem ser aninhados.

Embora todas as instruções Transact-SQL sejam válidas em um bloco BEGIN...END, certas instruções Transact-SQL não devem ser agrupadas no mesmo lote ou bloco de instrução.

Exemplos

No exemplo a seguir, BEGIN e END definem uma série de instruções Transact-SQL que são executadas em conjunto. Se o bloco BEGIN...END não tivesse sido incluído, ambas as instruções ROLLBACK TRANSACTION seriam executadas e as mensagens PRINT seriam retornadas.

USE AdventureWorks2012;
GO
BEGIN TRANSACTION;
GO
IF @@TRANCOUNT = 0
BEGIN
    SELECT FirstName, MiddleName 
    FROM Person.Person WHERE LastName = 'Adams';
    ROLLBACK TRANSACTION;
    PRINT N'Rolling back the transaction two times would cause an error.';
END;
ROLLBACK TRANSACTION;
PRINT N'Rolled back the transaction.';
GO
/*
Rolled back the transaction.
*/

Consulte também

Referência

ALTER TRIGGER (Transact-SQL)

Linguagem de controle de fluxo (Transact-SQL)

CREATE TRIGGER (Transact-SQL)

END (BEGIN...END) (Transact-SQL)