我有一个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:00
和17: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'