我在mytable中有以下行
date_start
-----------
2011-09-20 13:00:00
2011-10-01 13:14:00
2011-10-09 13:16:00
2011-09-27 15:00:00
2011-09-30 14:04:00
2011-10-03 14:00:00我有这样的疑问:
SELECT date_start
FROM `mytable`
WHERE date_start >= "2011-09-19"
AND date_start <= "2011-09-30"
LIMIT 0 , 30这里的问题是它只输出:
2011-09-20 13:00:00
2011-09-27 15:00:00我期待这样的结果:
2011-09-20 13:00:00
2011-09-27 15:00:00
2011-09-30 14:04:00因为如果我们查看查询,它应该包含以下内容作为结果:2011-09-30 14:04:00
我在这里做错了什么?
我也在mysql中使用了BETWEEN,但输出仍然是一样的。
任何帮助都将受到极大的感谢和奖励。
谢谢!
发布于 2011-10-06 14:19:31
作为日期时间处理的日期假定有00:00:00 :00小时:分钟:秒部分。因此,2011-09-30 14:04:00实际上是>= 2011-09-30。
要执行您想要的操作,请尝试:
SELECT date_start
FROM `mytable`
WHERE date(date_start) >= "2011-09-19"
AND date(date_start) <= "2011-09-30"
LIMIT 0 , 30发布于 2011-10-06 14:17:43
时间也被考虑在内。你应该像这样提到这一点
SELECT date_start
FROM `mytable`
WHERE date_start >= "2011-09-19"
AND date_start <= "2011-09-30 23:59:59"
LIMIT 0 , 30发布于 2011-10-06 14:17:38
2011-09-30将被解释为2011-09-30 00:00:00。尝试将范围的末尾设置为2011-09-30 23:59:59,这样就可以了。
https://stackoverflow.com/questions/7670774
复制相似问题