Compartir vía


Prioridad de operador (Transact-SQL)

Se aplica a: SQL Server Azure SQL Database Azure SQL Managed Instance Base de datos de Azure SQL de Microsoft Fabric

Cuando una expresión compleja tiene múltiples operadores, la prioridad de operador determina la secuencia en que se realizan las operaciones. El orden de ejecución puede afectar de manera significativa al valor resultante.

Los operadores tienen los niveles de prioridad que se muestran en la siguiente tabla. Un operador de los niveles más altos se evalúa antes que un operador de un nivel más bajo. En la tabla siguiente, 1 es el nivel más alto y 8 es el nivel más bajo.

Nivel Operadores
1 ~ (operador bit a bit NOT)
2 * (multiplicación), / (división), % (módulo)
3 + (positivo), - (negativo), + (suma), + (concatenación), - (resta), & (AND bit a bit), ^ (OR exclusivo bit a bit), | (OR bit a bit)
4 =, >, <, >=, <=, <>, !=, !>, !< (operadores de comparación)
5 NOT
6 y
7 ALL, ANY, BETWEEN, IN, LIKE, OR, SOME
8 = (asignación)

Cuando en una expresión dos operadores tienen el mismo nivel de prioridad, se evalúan de izquierda a derecha en función de su posición dentro de la expresión. Por ejemplo, en la expresión utilizada en la siguiente instrucción SET, el operador de resta se evalúa antes que el operador de suma.

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

Utilice paréntesis para suplantar la prioridad definida de los operadores en una expresión. Todo el contenido dentro del paréntesis se evalúa para obtener un valor único. Ese valor puede ser utilizado por cualquier otro operador fuera de los paréntesis.

Por ejemplo, en la expresión utilizada en la siguiente instrucción SET, el operador de multiplicación tiene una prioridad mayor que el operador de suma. La operación de multiplicación se evalúa antes; el resultado de la expresión es 13.

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

En la expresión utilizada en la siguiente instrucción SET, el paréntesis hace que primero se lleve a cabo la suma. El resultado de la expresión es 18.

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

Si una expresión tiene paréntesis anidados, se evalúa primero la expresión más anidada. El siguiente ejemplo contiene paréntesis anidados, con la expresión 5 - 3 en el conjunto de paréntesis más anidado. Esta expresión produce un valor de 2. Entonces, el operador de suma (+) suma este resultado a 4, dando como resultado 6. Finalmente, 6 se multiplica por 2 para producir un resultado de expresión 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;  

Consulte también

Operadores lógicos (Transact-SQL)
Operadores (Transact-SQL)
Funciones integradas (Transact-SQL)