Sql Server 问题之between and 使用注意事项
2012-07-04 16:25
886 查看
今天也遇到了下面问题。以后使用Between 都要注意了,最好不用!
1.问题:
有五条数据如下:
2010-12-01 12:16:10.000
2010-12-02 13:11:28.000
2010-12-03 13:49:15.000
2010-12-04 13:52:28.000
2010-12-05 13:52:28.000
我使用select * from table where [time] between '2010-12-1' and '2010-12-6' 能显示出这五条
如果我使用select * from sk_SmsSee where [time] between '2010-12-1' and '2010-12-5'
为什么就显示4条呢?
2010-12-01 12:16:10.000
2010-12-02 13:11:28.000
2010-12-03 13:49:15.000
2010-12-04 13:52:28.000
换句话说最后的日期总是不显示为什么呢?
经过测试 代码换成select * from table where [time]>='2010-12-1 12:00:00' and [time]<='2010-12-5 12:00:00' 也是显示4条。既然数据库中存在2010-12-5日的数据,那为什么[time]<='2010-12-5 ' 查不出来呢?
2.答案如下:
MS SQL Server 系统中使用Bewteen ... And 其作用域是闭区间,即包含左右边界值在内的。
另外在MS SQL 系统中对于日期DATE-->DATETIME隐式转化时,系统会自动增加 TIME字段00:00:00
即从日期型 " 2010-12-01" 隐式转化为 日期时间型时为 "2010-12-01 00:00:00"
所以对日期型使用Between ...AND...时,即实际只会包含另边值的部分值,可以使用半开半闭区间( >= && < )实现你所提到的问题。
1.问题:
有五条数据如下:
2010-12-01 12:16:10.000
2010-12-02 13:11:28.000
2010-12-03 13:49:15.000
2010-12-04 13:52:28.000
2010-12-05 13:52:28.000
我使用select * from table where [time] between '2010-12-1' and '2010-12-6' 能显示出这五条
如果我使用select * from sk_SmsSee where [time] between '2010-12-1' and '2010-12-5'
为什么就显示4条呢?
2010-12-01 12:16:10.000
2010-12-02 13:11:28.000
2010-12-03 13:49:15.000
2010-12-04 13:52:28.000
换句话说最后的日期总是不显示为什么呢?
经过测试 代码换成select * from table where [time]>='2010-12-1 12:00:00' and [time]<='2010-12-5 12:00:00' 也是显示4条。既然数据库中存在2010-12-5日的数据,那为什么[time]<='2010-12-5 ' 查不出来呢?
2.答案如下:
MS SQL Server 系统中使用Bewteen ... And 其作用域是闭区间,即包含左右边界值在内的。
另外在MS SQL 系统中对于日期DATE-->DATETIME隐式转化时,系统会自动增加 TIME字段00:00:00
即从日期型 " 2010-12-01" 隐式转化为 日期时间型时为 "2010-12-01 00:00:00"
所以对日期型使用Between ...AND...时,即实际只会包含另边值的部分值,可以使用半开半闭区间( >= && < )实现你所提到的问题。
相关文章推荐
- 时间类型数据使用between ...and ..语句条件查询时应注意的问题
- And,Where使用提示以及用+进行左关联的提示及注意事项
- 使用Microsoft Date And Time Picker Control 6.0(SP6)时要注意的小问题
- 有关STL使用上的一些注意事项。关于某些函数的参数问题。
- 基于HBase Thrift接口的一些使用问题及相关注意事项的详解
- redis的使用注意事项和问题总结
- 使用 MPMoviePlayerController 出现的问题、解决方法和注意事项
- HBase Thrift 接口的一些使用问题及相关注意事项
- 本地消息中删除自身界面出错的问题和cocos2dx使用多线程的注意事项
- Coolpy使用注意事项以及常见问题解决办法(持续更新中)
- Excel COM组件使用的注意事项和一些权限问题
- 安装和使用Oracle VM VirtualBox中的要点,注意事项和遇到的问题
- 使用SqlDependency监测SQL Server 2005/2008字段改动时的SQL语法及相关注意事项
- SQL Server中,timestamp类型使用注意事项
- SuperMap IS.NET是否使用SuperMap Deskpro出的地图预缓存及使用了预缓存后速度没有明显提高问题注意事项
- 通过项目中定位的一个问题:学习ionic框架$ionicPopover的使用以及注意事项
- python 多线程 join 的 细节问题 注意使用事项
- 解决Bootstrap 附加导航(Affix)的问题和使用时若干注意事项
- 关于使用对象和List时出现的问题和注意事项
- 英文版SQL Server 2008使用时,字段中存在中文的要注意编码问题