我有这样一个问题:
SELECT * FROM Cases WHERE created_at BETWEEN '2013-05-01' AND '2013-05-01'
但即使有1号的数据,这也没有给出结果.
created_at
看起来像2013-05-01 22:25:19
,我怀疑这和时间有关?如何解决这个问题?
如果我 Select 更大的日期范围,它就可以正常工作,但它也应该(包括)适用于单一日期.
我有这样一个问题:
SELECT * FROM Cases WHERE created_at BETWEEN '2013-05-01' AND '2013-05-01'
但即使有1号的数据,这也没有给出结果.
created_at
看起来像2013-05-01 22:25:19
,我怀疑这和时间有关?如何解决这个问题?
如果我 Select 更大的日期范围,它就可以正常工作,但它也应该(包括)适用于单一日期.
包括is英镑在内.您正在将日期时间与日期进行比较.第二个日期被解释为午夜when the day starts.
解决这个问题的一种方法是:
SELECT *
FROM Cases
WHERE cast(created_at as date) BETWEEN '2013-05-01' AND '2013-05-01'
另一种解决方法是使用显式二进制比较
SELECT *
FROM Cases
WHERE created_at >= '2013-05-01' AND created_at < '2013-05-02'
亚伦·伯特兰(Aaron Bertrand)有一篇关于日期(here)的长篇博客,他在博客中讨论了这个和其他日期问题.