Оператор BETWEEN (Transact-SQL)

Определяет диапазон для проверки.

Применимо для следующих объектов: SQL Server (SQL Server 2008 по текущую версию), База данных SQL Windows Azure (С первоначального выпуска по текущий выпуск).

Значок ссылки на раздел Cинтаксические обозначения в 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

Значение результата

Оператор BETWEEN возвращает значение TRUE: если значение аргумента test_expression больше значения аргумента begin_expression или равно ему и меньше значения аргумента end_expression или равно ему.

Оператор NOT BETWEEN возвращает значение TRUE: если значение аргумента test_expression меньше значения аргумента begin_expression или больше значения аргумента end_expression.

Замечания

Для задания исключающего диапазона используйте операторы «больше» (>) и «меньше» (<). Если любой параметр предиката BETWEEN или NOT BETWEEN имеет значение NULL, результат не определен (UNKNOWN).

Примеры

А.Использование оператора BETWEEN

В следующем примере выводятся имена сотрудников Компания Adventure Works Cycles, чья почасовая оплата находится в пределах от 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 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)

Б.Использование операторов > и < вместо BETWEEN

В следующем примере используются операторы «больше» (>) и «меньше» (<); так как они позволяют задавать исключающий диапазон, здесь выводятся только девять строк вместо десяти из предыдущего примера.

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)

В.Использование оператора 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

Г.Использование оператора BETWEEN со значениями типа datetime

В следующем примере возвращаются строки, в которых значения типа 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

Запрос извлекает ожидаемые строки, так как значения даты в запросе и значения типа datetime, хранящиеся в столбце RateChangeDate, были заданы без указания времени. Если время не указано, по умолчанию оно принимается равным 0:00. Обратите внимание, что строка, время в которой позднее 12:00. 05.01.2002, не будет возвращена данным запросом, так как она находится за пределами диапазона.

См. также

Справочник

> (больше) (Transact-SQL)

< (меньше) (Transact-SQL)

Выражения (Transact-SQL)

Встроенные функции (Transact-SQL)

Операторы (Transact-SQL)

SELECT (Transact-SQL)

Предложение WHERE (Transact-SQL)