適用於:SQL Server
Azure SQL Database
Azure SQL Managed Instance
Microsoft Fabric 中的 SQL 資料庫
當複雜運算式有多個運算子時,運算子優先順序會決定作業的順序。 執行的順序對結果值會有很大的影響。
下表顯示運算子的優先順序層級。 先評估層級較高的運算子,再評估層級較低的運算子。 在下表中,1 是最高層級,而 8 則是最低層級。
| Level | Operators |
|---|---|
| 1 | ~ (位元 NOT) |
| 2 | * (乘)、/ (除)、% (模數) |
| 3 | + (正)、-(負)、+ (加法)、+ (串連)、- (減法)、+ (位 AND)、^ (位獨佔 OR)、|(位元 OR) |
| 4 | =, >, <, >=, <=, <>, !=, !>, !< (比較運算子) |
| 5 | NOT |
| 6 | AND |
| 7 | ALL、ANY、BETWEEN、IN、LIKE、OR、SOME |
| 8 | =(分配) |
當運算式中兩個運算子有相同的優先順序層級時,會依據它們在運算式中的位置,由左至右來評估它們。 例如,在下列 SET 陳述式所用的運算式中,會先評估減法運算子,再評估加法運算子。
DECLARE @MyNumber INT;
SET @MyNumber = 4 - 2 + 27;
-- Evaluates to 2 + 27 which yields an expression result of 29.
SELECT @MyNumber;
請利用括號來覆寫運算式中,已定義的運算子優先順序。 括號內的所有項目都會受到求值,並得出單一值。 這些括號外的所有運算子都能使用該值。
例如,在下列 SET 陳述式所用的運算式中,乘法運算子的優先順序高於加法運算子。 乘法作業會優先受到求值;運算式結果為 13。
DECLARE @MyNumber INT;
SET @MyNumber = 2 * 4 + 5;
-- Evaluates to 8 + 5 which yields an expression result of 13.
SELECT @MyNumber;
在下列 SET 陳述式所用的運算式中,括號會使系統優先求值加法。 運算式結果是 18。
DECLARE @MyNumber INT;
SET @MyNumber = 2 * (4 + 5);
-- Evaluates to 2 * 9 which yields an expression result of 18.
SELECT @MyNumber;
如果運算式有巢狀括號,最內層的巢狀運算式最先評估。 下列範例包含巢狀括號,最內層的一組巢狀括號中的運算式是 5 - 3。 這個運算式會產生 2 值。 之後,加法運算子 (+) 會將這個結果加上 4,得出值 6。 最後,6 再乘以 2,得出運算式結果 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;