sql server 2005 T-SQL BETWEEN (Transact-SQL)
2007-12-21 10:35
417 查看
指定测试范围。
![](ms187922.05b1d166-d807-482c-891f-30b3b6b58046(zh-cn,SQL.90).gif)
Transact-SQL 语法约定
语法
参数
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 或 NOT BETWEEN 谓词的输入为 NULL,则结果为 UNKNOWN。
结果值
如果 test_expression 的值大于或等于 begin_expression 的值,并且小于或等于 end_expression 的值,则 BETWEEN 返回 TRUE。
如果 test_expression 的值小于 begin_expression 的值或者大于 end_expression 的值,则 NOT BETWEEN 返回 TRUE。
示例
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
由于指定查询中的日期值和 RateChangeDate 列中存储的 datetime 值时未指定日期的时间部分,因此该查询将检索预期行。未指定时间部分时,将默认使用 12:00 A.M。注意,若某行的时间部分晚于 1998-0105 12:00 A.M.,则由于它处于范围之外,因此不返回该行。
![](ms187922.05b1d166-d807-482c-891f-30b3b6b58046(zh-cn,SQL.90).gif)
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 或 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 中每小时薪金在 27 和 30 之间的雇员。![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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
下面的示例使用大于 (>) 和小于 (<) 运算符,因为这些运算符是非包含的,所以该示例返回九行,而不是像上一个示例那样返回十行。![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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
下面的示例查找处于指定范围 27 到 30 以外的所有行。![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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'(含)之间的行。![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
USE AdventureWorks GO SELECT EmployeeID, RateChangeDate FROM HumanResources.EmployeePayHistory WHERE RateChangeDate BETWEEN '19971212' AND '19980105'
下面是结果集:
![](http://blog.csdn.net/Platform/Controls/CodeSnippet/resources/copy_off.gif)
复制代码
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.,则由于它处于范围之外,因此不返回该行。
相关文章推荐
- sql server 2005 T-SQL BETWEEN (Transact-SQL)
- SQL Server 2005 Beta 2 Transact-SQL 增强功能 1(转)
- sql server 2005 T-SQL % (通配符 -- 需匹配的字符)(Transact-SQL)
- sql server 2005 T-SQL --(注释)(Transact-SQL)
- sql server 2005 T-SQL @@CURSOR_ROWS (Transact-SQL)
- sql server 2005 T-SQL @@LANGID (Transact-SQL)
- sql server 2005 T-SQL @@PACK_SENT (Transact-SQL)
- sql server 2005 T-SQL @@TEXTSIZE (Transact-SQL)
- sql server 2005 T-SQL ALTER LOGIN (Transact-SQL)
- sql server 2005 T-SQL ALTER ROUTE (Transact-SQL)
- sql server 2005 T-SQL ALTER VIEW (Transact-SQL)
- sql server 2005 T-SQL BACKUP CERTIFICATE (Transact-SQL)
- sql server 2005 T-SQL binary 和 varbinary (Transact-SQL)
- sql server 2005 T-SQL @@DBTS (Transact-SQL)
- sql server 2005 T-SQL @@LOCK_TIMEOUT (Transact-SQL)
- sql server 2005 T-SQL @@PACK_RECEIVED (Transact-SQL)
- sql server 2005 T-SQL @@TOTAL_ERRORS (Transact-SQL)
- sql server 2005 T-SQL ALTER FULLTEXT CATALOG (Transact-SQL)
- sql server 2005 T-SQL BEGIN...END (Transact-SQL)
- sql server 2005 T-SQL BULK INSERT (Transact-SQL)