(Transact-SQL ARASıNDA)
Sınanacak aralık belirtir.
test_expression [ NOT ] BETWEEN begin_expression AND end_expression
Bağımsız değişkenler
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.NOT
Yüklemi sonucu negated belirtir.begin_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.AND
Gösteren yer tutucu olarak davranır test_expression tarafından belirtilen aralık içinde olmalıdır begin_expression ve end_expression.
Sonuç türleri
Boolean
Sonuç değeri
Verir TRUE değeri test_expression değerine eşit veya büyük begin_expression ve değeri küçük veya eşit end_expression.
ARASıNDA DEĞIL döndürür. TRUE değeri test_expression değeri'dan küçük begin_expression veya değeri çok büyük end_expression.
Remarks
Özel bir aralık belirtmek için , büyük kullanın ()'den>) ve işleçler ()'dan<). Varsa için BETWEEN giriş veya BETWEEN yüklemi NOT NULL olduğu için BILINMEYEN sonucudur.
Örnekler
C.BETWEEN kullanma
Aşağıdaki örnek, çalışanlar verir... Adventure Works Cycles bir saatlik ödeme kuru arasındaki olan 27 ve 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.Bu alternatif > ve < yerine, BETWEEN
Aşağıdaki örnek, büyüktür () kullanır.>) ve ()'dan<) işleçlerini ve bu işleçleri dahil olduğu için önceki örnekte döndürülmedi yerine on dokuz satırları döndürür.
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.NOT ARASıNDA kullanma
Aşağıdaki örnek belirtilen aralık dışındaki tüm satırları bulur. 27 arasında 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.Datetime değerleri ARASıNDA kullanma
Aşağıdaki örnek, satırları alır. datetime arasındaki değerlerdir '19971212' ve '19980105', (dahil) arasındadır.
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
Sorgu, sorguda tarih değerleri için beklenen satırlar alır ve datetime depolanan değerler RateChangeDate Sütun belirtilen tarih saat parçası. Saat bölümü belirtilmezse, 12: 00'da için varsayılan...Note 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.