Precedência dos operadores (Transact-SQL)

Quando uma expressão complexa tiver vários operadores, A precedência de operador determina a seqüência na qual as operações são executadas. A ordem de execução pode afetar o valor resultante significativamente.

Os níveis de precedência dos operadores são mostrados na tabela a seguir. Um operador em níveis superiores é avaliado antes de um operador em um nível inferior.

Nível

Operadores

1

~ (Não de bit a bit)

2

* (Multiplicação), / (Divisão),% (Módulo)

3

+ (Positivo), - (Negativo), + (Adição), + (Concatenar) - (Subtração) & (AND de bit a bit), ^ (OR Exclusivo de bit a bit), | (OR de bit a bit)

4

=, >, <, >=, <=, <>, !=, !>, !< (Operadores de comparação)

5

NOT

6

AND

7

ALL, ANY, BETWEEN, IN, LIKE, OR, SOME

8

= (Atribuição)

Quando dois operadores em uma expressão tiverem o mesmo nível de precedência de operador, eles serão avaliados da esquerda para a direita em sua posição na expressão. Por exemplo, na expressão usada na seguinte instrução SET, o operador de subtração é avaliado antes do operador de adição.

DECLARE @MyNumber int
SET @MyNumber = 4 - 2 + 27
-- Evaluates to 2 + 27 which yields an expression result of 29.
SELECT @MyNumber

Use parênteses para substituir a precedência definida dos operadores em uma expressão. Tudo que estiver entre parênteses é avaliado primeiro para gerar um único valor antes daquele que poderá ser usado por qualquer operador fora dos parênteses.

Por exemplo, na expressão usada na seguinte instrução SET, o operador de multiplicação tem uma precedência maior que o operador de adição. Portanto, ele é avaliado primeiro; o resultado da expressão é 13.

DECLARE @MyNumber int
SET @MyNumber = 2 * 4 + 5
-- Evaluates to 8 + 5 which yields an expression result of 13.
SELECT @MyNumber

Na expressão usada na seguinte instrução SET, os parênteses fazem com que a adição seja executada primeiro. O resultado da expressão é 18.

DECLARE @MyNumber int
SET @MyNumber = 2 * (4 + 5)
-- Evaluates to 2 * 9 which yields an expression result of 18.
SELECT @MyNumber

Se uma expressão tiver parênteses aninhados, a expressão mais aninhada será avaliada primeiro. O exemplo a seguir contém parênteses aninhados, com a expressão 5 - 3 no conjunto de parênteses mais aninhado. Essa expressão gera um valor de 2. Em seguida, o operador de adição (+) adiciona esse resultado a 4. Isso gera um valor de 6. Finalmente, os 6 são multiplicados por 2 para gerar um resultado de expressão de 12.

DECLARE @MyNumber int
SET @MyNumber = 2 * (4 + (5 - 3) )
-- Evaluates to 2 * (4 + 2) which then evaluates to 2 * 6, and 
-- yields an expression result of 12.
SELECT @MyNumber