BETWEEN (Transact-SQL)

更新日期: 2006 年 4 月 14 日

指定测试范围。

主题链接图标Transact-SQL 语法约定

语法

test_expression [ NOT ] BETWEEN begin_expression AND end_expression

参数

  • 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 指定的范围内。

结果类型

Boolean

备注

若要指定排他范围,请使用大于 (>) 和小于 (<) 运算符。如果任何 BETWEEN 或 NOT BETWEEN 谓词的输入为 NULL,则结果为 UNKNOWN。

结果值

如果 test_expression 的值大于或等于 begin_expression 的值,并且小于或等于 end_expression 的值,则 BETWEEN 返回 TRUE

如果 test_expression 的值小于 begin_expression 的值或者大于 end_expression 的值,则 NOT BETWEEN 返回 TRUE

示例

A. 使用 BETWEEN

以下示例返回 Adventure Works Cycles 中每小时薪金在 2730 之间的雇员。

USE AdventureWorks;
GO
SELECT e.FirstName, e.LastName, ep.Rate
FROM HumanResources.vEmployee e 
JOIN HumanResources.EmployeePayHistory ep 
    ON e.EmployeeID = ep.EmployeeID
WHERE ep.Rate BETWEEN 27 AND 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
Sheela      Word                    30.0000
(10 row(s) affected)

B. 使用 > 和 <,而不使用 BETWEEN

下面的示例使用大于 (>) 和小于 (<) 运算符,因为这些运算符是非包含的,所以该示例返回九行,而不是像上一个示例那样返回十行。

USE AdventureWorks;
GO

SELECT e.FirstName, e.LastName, ep.Rate
FROM HumanResources.vEmployee e 
JOIN HumanResources.EmployeePayHistory ep 
    ON e.EmployeeID = ep.EmployeeID
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

下面的示例查找处于指定范围 2730 以外的所有行。

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

D. 使用带有日期时间值的 BETWEEN

以下示例将检索 datetime 值介于 '19971212''19980105'(含)之间的行。

USE AdventureWorks
GO
SELECT EmployeeID, RateChangeDate
FROM HumanResources.EmployeePayHistory
WHERE RateChangeDate BETWEEN '19971212' AND '19980105'

下面是结果集:

 EmployeeID RateChangeDate
----------- -----------------------
          3 1997-12-12 00:00:00.000
          4 1998-01-05 00:00:00.000

由于指定查询中的日期值和 RateChangeDate 列中存储的 datetime 值时未指定日期的时间部分,因此该查询将检索预期行。未指定时间部分时,将默认使用 12:00 A.M。注意,若某行的时间部分晚于 1998-0105 12:00 A.M.,则由于它处于范围之外,因此不返回该行。

请参阅

参考

>(大于)(Transact-SQL)
<(小于)(Transact-SQL)
表达式(Transact-SQL)
Functions (Transact-SQL)
运算符 (Transact-SQL)
SELECT (Transact-SQL)
WHERE (Transact-SQL)

其他资源

逻辑运算符
子查询基础知识

帮助和信息

获取 SQL Server 2005 帮助

更改历史记录

版本 历史记录

2006 年 4 月 14 日

新增内容:
  • 添加了新示例 D,该示例使用带有日期值的 BETWEEN。