BETWEEN (Transact-SQL)

適用於:Microsoft Fabric 中 Microsoft Fabric倉儲中的 SQL ServerAzure SQL 資料庫 Azure SQL 受控執行個體 Azure Synapse AnalyticsAnalytics Platform System (PDW)SQL 分析端點

指定要測試的範圍。

Transact-SQL 語法慣例

Syntax

test_expression [ NOT ] BETWEEN begin_expression AND end_expression  

注意

若要檢視 SQL Server 2014 (12.x) 和舊版的 Transact-SQL 語法,請參閱 舊版檔

引數

test_expression
這是要在 begin_expressionend_expression 定義的範圍中測試的運算式test_expression 的資料類型必須與 begin_expressionend_expression 相同。

NOT
指定執行否定運算的述詞結果。

begin_expression
為任何有效運算式。 begin_expression 的資料類型必須與 test_expressionend_expression 相同。

end_expression
為任何有效運算式。 end_expression 的資料類型必須與 test_expressionbegin_expression 相同。

AND
用來作為預留位置,表示 test_expression 應該位於 begin_expressionend_expression 所指定的範圍內。

結果類型

布林值

結果值

如果 test_expression 的值大於或等於 begin_expression 的值且小於或等於 end_expression 的值,BETWEEN 就會傳回 TRUE

如果 test_expression 的值小於 begin_expression 的值或大於 end_expression 的值,NOT BETWEEN 就會傳回 TRUE

備註

若要指定獨佔範圍,請使用大於 (>) 和小於 (<) 運算子。 如果 BETWEEN 或 NOT BETWEEN 述詞的任何輸入是 NULL,結果就是 UNKNOWN。

範例

A. 使用 BETWEEN

下列範例會傳回資料庫中資料庫角色的相關資訊。 第一個查詢會傳回所有角色。 第二個範例會使用 BETWEEN 子句,將角色限制為指定的 database_id 值。

SELECT principal_id, name 
FROM sys.database_principals
WHERE type = 'R';

SELECT principal_id, name 
FROM sys.database_principals
WHERE type = 'R'
AND principal_id BETWEEN 16385 AND 16390;
GO  

以下為結果集。

principal_id	name
------------  ---- 
0	            public
16384	        db_owner
16385	        db_accessadmin
16386	        db_securityadmin
16387	        db_ddladmin
16389	        db_backupoperator
16390	        db_datareader
16391	        db_datawriter
16392	        db_denydatareader
16393	        db_denydatawriter
principal_id	name
------------  ---- 
16385	        db_accessadmin
16386	        db_securityadmin
16387	        db_ddladmin
16389	        db_backupoperator
16390	        db_datareader

B. 使用 > 和 < 來取代 BETWEEN

下列範例使用大於 (>) 和小於 (<) 運算子,因為這些運算子頭尾不包括在內,因此,不像前一個範例傳回 10 個資料列,它只會傳回 9 個資料列。

-- Uses AdventureWorks  
  
SELECT e.FirstName, e.LastName, ep.Rate  
FROM HumanResources.vEmployee e   
JOIN HumanResources.EmployeePayHistory ep   
    ON e.BusinessEntityID = ep.BusinessEntityID  
WHERE ep.Rate > 27 AND ep.Rate < 30  
ORDER BY ep.Rate;  
GO  

以下為結果集。

FirstName   LastName             Rate  
---------   -------------------  ---------  
Paula       Barreto de Mattos    27.1394  
Janaina     Bueno                27.4038  
Dan         Bacon                27.4038  
Ramesh      Meyyappan            27.4038  
Karen       Berg                 27.4038  
David       Bradley              28.7500  
Hazem       Abolrous             28.8462  
Ovidiu      Cracium              28.8462  
Rob         Walters              29.8462  

C. 使用 NOT BETWEEN

下列範例會找出不在指定範圍 2730 之間的所有資料列。

-- Uses AdventureWorks  
  
SELECT e.FirstName, e.LastName, ep.Rate  
FROM HumanResources.vEmployee e   
JOIN HumanResources.EmployeePayHistory ep   
    ON e.BusinessEntityID = ep.BusinessEntityID  
WHERE ep.Rate NOT BETWEEN 27 AND 30  
ORDER BY ep.Rate;  
GO  

D. 使用含有 datetime 值的 BETWEEN

下列範例會擷取 datetime 值介於 '20011212''20020105' (含) 之間的資料列。

-- Uses AdventureWorks  
  
SELECT BusinessEntityID, RateChangeDate  
FROM HumanResources.EmployeePayHistory  
WHERE RateChangeDate BETWEEN '20011212' AND '20020105';  

以下為結果集。

BusinessEntityID RateChangeDate  
----------- -----------------------  
3           2001-12-12 00:00:00.000  
4           2002-01-05 00:00:00.000  

查詢會擷取預期的資料列,因為已指定查詢中的日期值以及儲存在 RateChangeDate 資料行中的 datetime 值不含日期的時間部分。 未指定時間部份時,預設為上午 12:00。請注意若資料列包含 2002 年 1 月 5 日上午 12:00 之後的時間部分,此查詢將不會傳回該資料列,因為其是在範圍之外。

另請參閱

> (大於) (Transact-SQL)
< (小於) (Transact-SQL)
運算式 (Transact-SQL)
內建函數 (Transact-SQL)
運算子 (Transact-SQL)
SELECT (Transact-SQL)
WHERE (Transact-SQL)