Usar os blocos IF e WHILE para controlar o fluxo do programa
Todas as linguagens de programação incluem elementos que ajudam você a determinar o fluxo do programa ou a ordem na qual as instruções são executadas. Embora não seja tão completo quanto linguagens como C#, o T-SQL fornece um conjunto de palavras-chave de controle de fluxo que você pode usar para executar testes lógicos e criar loops que contêm suas instruções de manipulação de dados T-SQL. Nesta lição, você aprenderá a usar as palavras-chave T-SQL IF e WHILE.
Entender o controle T-SQL da linguagem de fluxo
O SQL Server fornece elementos de linguagem que controlam o fluxo de execução do programa em lotes T-SQL, procedimentos armazenados e funções definidas pelo usuário de várias instruções. Esses elementos de controle de fluxo significam que você pode determinar programaticamente se as instruções devem ser executadas e determinar programaticamente a ordem dessas instruções que devem ser executadas.
Esses elementos incluem, mas não se limitam a:
- SE... ELSE, que executa código com base em uma expressão booliana.
- WHILE, que cria um loop que é executado desde que uma condição seja verdadeira.
- BEGIN…END, que define uma série de instruções T-SQL que devem ser executadas conjuntamente.
- Outras palavras-chave, por exemplo, BREAK, CONTINUE, WAITFOR e RETURN, que são usadas para dar suporte a operações de controle de fluxo T-SQL.
Consulte um exemplo de uma instrução IF:
IF OBJECT_ID('dbo.tl') IS NOT NULL
DROP TABLE dbo.tl
GO
Usar a lógica condicional nos seus programas usando IF...ELSE
A estrutura IF...ELSE é usada no T-SQL para executar condicionalmente um bloco de código com base em um predicado. A instrução IF determina se a instrução ou o bloco a seguir (se BEGIN... END é usado) é executado. Se o predicado for avaliado como TRUE, o código no bloco será executado. Quando o predicado é avaliado como FALSE ou UNKNOWN, o bloco não é executado, a menos que a palavra-chave ELSE opcional seja usada para identificar outro bloco de código.
Na instrução IF a seguir, estamos perguntando ao banco de dados se o OBJECT_ID é NULL e, em caso afirmativo, retorna a instrução PRINT. Neste exemplo, o objeto NÃO é nulo e, portanto, FALSE, o que significa que o código BEGIN/END não será executado. A instrução PRINT só será executada se o objeto não existir no banco de dados.
USE TSQL;
GO
IF OBJECT_ID('HR.Employees') IS NULL --this object does exist in the sample database
BEGIN
PRINT 'The specified object does not exist';
END;
Devido às limitações com o código acima com apenas uma instrução IF, isso pode ser confuso. Combinar IF e ELSE oferece mais flexibilidade com a lógica em seu código e você pode usar várias instruções ELSE. Com o uso de ELSE, você tem outra opção de execução quando o predicado IF é avaliado como FALSE ou UNKNOWN, como no exemplo a seguir:
IF OBJECT_ID('HR.Employees') IS NULL --this object does exist in the sample database
BEGIN
PRINT 'The specified object does not exist';
END
ELSE
BEGIN
PRINT 'The specified object exists';
END;
Nas operações de manipulação de dados, usar IF com a palavra-chave EXISTS pode ser uma ferramenta útil para verificar a existência eficiente, como no seguinte exemplo:
IF EXISTS (SELECT * FROM Sales.EmpOrders WHERE empid =5)
BEGIN
PRINT 'Employee has associated orders';
END;
Noções básicas sobre o loop usando as instruções WHILE
A instrução WHILE é usada para executar código em um loop com base em um predicado. Assim como a instrução IF, a instrução WHILE determina se a instrução ou o bloco a seguir (se BEGIN... END é usado) é executado. O loop continua a ser executado desde que a condição seja avaliada como TRUE. Normalmente, você controla o loop com uma variável testada pelo predicado e manipulada no próprio corpo do loop.
O seguinte exemplo usa a variável @empid no predicado e altera o valor dela no bloco BEGIN...END:
DECLARE @empid AS INT = 1, @lname AS NVARCHAR(20);
WHILE @empid <=5
BEGIN
SELECT @lname = lastname FROM HR.Employees
WHERE empid = @empid;
PRINT @lname;
SET @empid += 1;
END;
Para opções extras em um loop WHILE, você pode usar as palavras-chave CONTINUE e BREAK para controlar o fluxo.