繁体   English   中英

Mysql查询只回到午夜

[英]Mysql Query back to midnight only

我有这个查询在过去的二十分钟内查找数据库的结果,现在我知道如何在几小时,几天等内查找,但是有可能只查看当天的午夜。 所以什么时候运行查询,什么时候它只回溯到午夜?

SELECT * FROM ip_stats WHERE date >= ( NOW() - INTERVAL 20 MINUTE ) and ip='$ip'

这是我的代码,但在那里我可以替换特定时间的间隔。

任何帮助,将不胜感激。

回顾当天的午夜与查看没有时间成分的当前日期相同。 因此,您可以使用DATE()将日期时间列date截断为仅日期部分,并将其与CURDATE()进行比较。

SELECT * FROM ip_stats WHERE DATE(date) = CURDATE() and ip='$ip'
SELECT * FROM ip_stats WHERE date >= ( NOW() - INTERVAL 20 MINUTE ) AND date >= CURDATE() and ip='$ip'

只需使列date大于curdate (这是今天的开始)。

SELECT * FROM ip_stats 
WHERE date >= ( NOW() - INTERVAL 20 MINUTE ) 
and date > CURDATE()
and ip='$ip'

您可以使用CURDATE()从当天午夜起获取行:

SELECT * FROM ip_stats WHERE date >= CURDATE() and ip='$ip'
SELECT * FROM ip_stats WHERE date >= GREATEST( NOW() - INTERVAL 20 MINUTE, CURRENT_DATE ) AND ip = '$ip'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM