Mysql在两个日期/时间之间选择


mysql select between two dates / times

我有一个mysql数据库,有一个日期字段以及一个时间字段。我需要从数据库中选择以下参数。

select from spiff,其中日期在02/01/2016之间,时间等于或大于12:00:00,日期02/08/2016,时间等于或小于11:59:59

所以在简单的论坛中,我想选择从7天前到今天的所有内容从中午到中午,其中12;00:00是截止时间。

我有这段代码,但是它并没有达到我想要的效果

SELECT * 
FROM spiff 
WHERE `date` BETWEEN '" . $week_before . "' AND  '" . $today . "' AND time <= '12:00:00'  
ORDER by id DESC

这行不通。您不能将日期和时间存储在单独的字段中,然后同时搜索这两个字段。您排除了所有晚于"中午"的时间,这意味着如果您有这些日期/时间:

02/02/2016 13:00    excluded
02/03/2016 10:00    included
02/04/2016 17:59    excluded

即使这些日期在您指定的范围内,13:0017:59也被排除,因为它们不是< '12:00:00'

您需要将日期存储为单个datetime字段,然后您的查询变得微不足道:

SELECT ... WHERE datetimefield BETWEEN '2016-02-01 12:00:00' AND '2016-02-08 11:59:59'

注意,对于这些类型的日期/时间比较工作,你必须使用mysql的实际日期/时间字段,和mysql的日期作为时间字符串格式:yyyy-mm-dd。如果你的日期被存储为mm/dd/yyyy,那么它们不是日期,它们是字符串,mysql的字符串比较规则适用,这意味着

'10/11/2015' > '09/01/1970' -> TRUE

因为10大于09

问题是日期和时间部分在不同的字段中。由于where子句中的AND time <= '12:00:00'条件,MySQL将返回所有受影响日期的早晨记录。

最好的解决方案是将这两个字段合并为一个datetime数据类型的字段。这样where子句就是:

...`datime_field` BETWEEN '" . $week_before_noon . "' AND  '" . $today_noon . "'

两个php变量将包含YYYY-MM-DD hh:mm:ss格式的有效日期时间表达式

另一种解决方案是动态地组合两个字段的值,但是这样就不能使用索引来加速搜索:

... date + time BETWEEN '" . $week_before . " 12:00:00' AND  '" . $today . " 12:00:00'