共用方式為


BETWEEN (Transact-SQL)

指定要測試的範圍。

主題連結圖示 Transact-SQL 語法慣例

語法

test_expression [ NOT ] BETWEEN begin_expression AND end_expression

引數

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

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

  • begin_expression
    任何有效的運算式。 begin_expression 必須與 test_expression 和 end_expression 是相同的資料類型。

  • end_expression
    任何有效的運算式。 end_expression 必須與 test_expression和 begin_expression 是相同的資料類型。

  • AND
    作為一個預留位置,用來指出 test_expression 應該在 begin_expression 和 end_expression 所指示的範圍內。

結果類型

Boolean

結果值

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

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

備註

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

範例

A.使用 BETWEEN

下列範例會傳回時薪在 27 和 30 之間的 Adventure Works Cycles 員工。

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

以下為結果集:

FirstName    LastName            Rate

-----------  ------------------  ------------------

Paula        Barreto de Mattos   27.1394

Karen        Berg                27.4038

Ramesh       Meyyappan           27.4038

Dan          Bacon               27.4038

Janaina      Bueno               27.4038

David        Bradley             28.7500

Hazem        Abolrous            28.8462

Ovidiu       Cracium             28.8462

Rob          Walters             29.8462

Sheela       Word                30.0000

(10 row(s) affected)

B.利用 > 和 < 來取代 BETWEEN

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

USE AdventureWorks2012;
GO

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

(9 row(s) affected)

C.使用 NOT BETWEEN

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

USE AdventureWorks2012;
GO
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' 的資料列。

USE AdventureWorks2012;
GO
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-01-05 上午 12:00 之後的時間部分, 此查詢將不會傳回該資料列,因為它是在範圍之外。

請參閱

參考

> (大於) (Transact-SQL)

< (小於) (Transact-SQL)

運算式 (Transact-SQL)

內建函數 (Transact-SQL)

運算子 (Transact-SQL)

SELECT (Transact-SQL)

WHERE (Transact-SQL)