BETWEEN (Transact-SQL)
sp_columns_rowset2
test_expression [ NOT ] BETWEEN begin_expression AND end_expression
Argumenty
test_expression
Is the expression to test for in the range defined by begin_expressionand end_expression.test_expression must be the same data type as both begin_expression and end_expression.NIE
sp_datatype_info_90begin_expression
Is any valid expression.begin_expression must be the same data type as both test_expression and end_expression.end_expression
Is any valid expression.end_expression must be the same data type as both test_expressionand begin_expression.ORAZ
Działania jako symbol zastępczy, który wskazuje test_expression powinien znajdować się w zakresie zakres wskazanej przez begin_expression i end_expression.
Typy wynik
Boolean
Wartość wyniku
BETWEEN zwraca TRUE Jeśli wartość test_expression jest większe niż lub równa wartości begin_expression i mniejsza niż lub równa wartości end_expression.
NIE między zwraca TRUE Jeśli wartość test_expression jest mniejsza niż wartość begin_expression lub większa niż wartość end_expression.
Remarks
Aby określić zakres wyłączności, należy użyć większy niż ()>) i mniejszą niż operatory ()<). sp_ddopen; 3
Przykłady
A.sp_ddopen; 4
W poniższym przykładzie są zwracane pracowników Adventure Works Cycles mają kursu płaca godzinowa między 27 i 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
Here is the result set.
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.Za pomocą > i < zamiast BETWEEN
W poniższym przykładzie użyto większe niż)>) i mniejszy niż ()<) operatory, ponieważ te podmioty nie włącznie, zwraca dziewięciu wierszy zamiast z 10, które zostały zwrócone w poprzednim przykładzie.
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
Here is the result set.
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.sp_ddopen; 8
Następujący przykład wyszukuje wszystkie wiersze poza określonym zakres z 27 za pomocą 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
D.sp_foreign_keys_rowset
Poniższy przykład pobiera wiersze, w którym datetime są wartości z przedziału '19971212' i '19980105', włącznie.
USE AdventureWorks
GO
SELECT EmployeeID, RateChangeDate
FROM HumanResources.EmployeePayHistory
WHERE RateChangeDate BETWEEN '19971212' AND '19980105'
Here is the result set.
EmployeeID RateChangeDate
----------- -----------------------
3 1997-12-12 00:00:00.000
4 1998-01-05 00:00:00.000
Oczekiwano wierszy pobieranych przez kwerendę, ponieważ wartości data w kwerendzie i datetime wartości przechowywane w RateChangeDate kolumna zostały określone bez czas część data. sp_foreign_keys_rowset; 5Note that a row that contains a time part that is after 12:00 A.M.on 1998-0105 would not be returned by this query because it falls outside the range.