首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL "between“不包含

SQL "between“不包含
EN

Stack Overflow用户
提问于 2013-05-03 05:01:12
回答 8查看 182.9K关注 0票数 163

我有一个类似这样的查询:

代码语言:javascript
复制
SELECT * FROM Cases WHERE created_at BETWEEN '2013-05-01' AND '2013-05-01'

但是,即使有1号的数据,这也没有给出任何结果。

created_at看起来像2013-05-01 22:25:19,我猜这和时间有关?如何解决这个问题呢?

如果我使用更大的日期范围,它工作得很好,但它也应该(包括)与单个日期一起工作。

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2013-05-03 05:03:37

它是包容性的。您正在将日期时间与日期进行比较。第二个日期被解释为当天开始时的午夜。

解决此问题的一种方法是:

代码语言:javascript
复制
SELECT *
FROM Cases
WHERE cast(created_at as date) BETWEEN '2013-05-01' AND '2013-05-01'

另一种修复方法是显式的二进制比较

代码语言:javascript
复制
SELECT *
FROM Cases
WHERE created_at >= '2013-05-01' AND created_at < '2013-05-02'

Aaron Bertrand有一篇关于日期的长篇博客文章(here),在那里他讨论了这个和其他日期问题。

票数 346
EN

Stack Overflow用户

发布于 2013-05-03 05:05:54

您需要执行以下两个选项之一:

  1. 在您的between条件中包含时间部分:... where created_at between '2013-05-01 00:00:00' and '2013-05-01 23:59:59' (不推荐...参见最后一段)
  2. 使用不等式而不是between。注意,然后您必须在第二个值的基础上添加一天:... where (created_at >= '2013-05-01' and created_at < '2013-05-02')

我个人的偏好是第二个选择。此外,有a very clear explanation on why它应该被使用。

票数 19
EN

Stack Overflow用户

发布于 2015-09-13 03:13:21

只需使用时间戳作为日期:

代码语言:javascript
复制
SELECT * FROM Cases WHERE date(created_at)='2013-05-01' 
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16347649

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档