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

时间:2016-09-09 14:42:15

标签: php mysql date time

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

从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

2 个答案:

答案 0 :(得分:0)

那不行。您不能将日期和时间存储在单独的字段中,然后按两者搜索。您排除的时间超过&#34;中午和#34;,这意味着如果您有这些日期/时间:

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

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

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

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

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

mm/dd/yyyy

因为'10/11/2015' > '09/01/1970' -> TRUE 大于10

答案 1 :(得分:0)

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

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

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

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

另一种解决方案是动态组合来自2个字段的值,但这样您就无法使用索引来加速搜索:

... date + time BETWEEN '" . $week_before . " 12:00:00' AND  '" . $today . " 12:00:00'
相关问题