我有这个查询在过去的二十分钟内查找数据库的结果,现在我知道如何在几小时,几天等内查找,但是有可能只在当天的午夜查找。所以什么时候运行查询,什么时候它只能回溯到午夜?
SELECT * FROM ip_stats WHERE date >= ( NOW() - INTERVAL 20 MINUTE ) and ip='$ip'
这是我的代码,但在那里我可以替换特定时间的间隔。
任何帮助都将不胜感激。
答案 0 :(得分:22)
回顾当天的午夜与查看没有时间成分的当前日期相同。因此,您可以使用DATE()
将日期时间列date
截断为仅日期部分,并将其与CURDATE()
进行比较。
SELECT * FROM ip_stats WHERE DATE(date) = CURDATE() and ip='$ip'
答案 1 :(得分:1)
SELECT * FROM ip_stats WHERE date >= ( NOW() - INTERVAL 20 MINUTE ) AND date >= CURDATE() and ip='$ip'
答案 2 :(得分:0)
只需让列date
大于curdate
(这是今天的开头)。
SELECT * FROM ip_stats
WHERE date >= ( NOW() - INTERVAL 20 MINUTE )
and date > CURDATE()
and ip='$ip'
答案 3 :(得分:0)
您可以使用CURDATE()
从当天午夜开始获取行:
SELECT * FROM ip_stats WHERE date >= CURDATE() and ip='$ip'
答案 4 :(得分:0)
SELECT *
FROM ip_stats
WHERE date >= GREATEST( NOW() - INTERVAL 20 MINUTE, CURRENT_DATE )
AND ip = '$ip'