Sql Server 问题之between and 使用注意事项

今天也遇到了下面问题。以后使用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...时,即实际只会包含另边值的部分值,可以使用半开半闭区间( >= && < )实现你所提到的问题。

转载于:https://www.cnblogs.com/Tonyyang/archive/2012/07/04/2576431.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值