BETWEEN (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 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)
Б. Использование операторов > и < вместо 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)
В. Использование оператора NOT BETWEEN
В следующем примере выводятся все строки вне указанного диапазона от 27 до 30.
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
Г. Использование оператора BETWEEN со значениями типа datetime
В следующем примере возвращаются строки, в которых значения типа 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
Запрос извлекает ожидаемые строки, так как значения даты в запросе и значения типа datetime, хранящиеся в столбце RateChangeDate, были заданы без указания времени. Если время не указано, по умолчанию оно принимается равным 0:00. Обратите внимание, что строка, время в которой позднее 0:00 05.01.1998, не будет возвращена данным запросом, так как она не попадает в диапазон.