我正在寻找一个where子句,可用于检索过去24小时的记录?


当前回答

select ...
from ...
where YourDateColumn >= getdate()-1

其他回答

在MySQL中:

SELECT  *
FROM    mytable
WHERE   record_date >= NOW() - INTERVAL 1 DAY

在SQL Server中:

SELECT  *
FROM    mytable
WHERE   record_date >= DATEADD(day, -1, GETDATE())

在Oracle中:

SELECT  *
FROM    mytable
WHERE   record_date >= SYSDATE - 1

在PostgreSQL:

SELECT  *
FROM    mytable
WHERE   record_date >= NOW() - '1 day'::INTERVAL

红移:

SELECT  *
FROM    mytable
WHERE   record_date >= GETDATE() - '1 day'::INTERVAL

SQLite:

SELECT  *
FROM    mytable
WHERE   record_date >= datetime('now','-1 day')

在MS Access中:

SELECT  *
FROM    mytable
WHERE   record_date >= (Now - 1)
select ...
from ...
where YourDateColumn >= getdate()-1

在SQL Server中(过去24小时):

SELECT  *
FROM    mytable
WHERE   order_date > DateAdd(DAY, -1, GETDATE()) and order_date<=GETDATE()

你好,我现在从原来的帖子过去了很多时间,但我有一个类似的问题,我想分享。

我得到了一个datetime字段,格式为YYYY-MM-DD hh:mm:ss,我想访问一整天,所以这是我的解决方案。

函数DATE(),在MySQL:提取日期或日期时间表达式的日期部分。

SELECT * FROM `your_table` WHERE DATE(`your_datatime_field`)='2017-10-09'

这一天我得到了所有的行寄存器。

我希望它能帮助到任何人。

如果考虑的时间戳是UNIX时间戳 您需要首先将UNIX时间戳(例如1462567865)转换为mysql时间戳或数据

SELECT * FROM `orders` WHERE FROM_UNIXTIME(order_ts) > DATE_SUB(CURDATE(), INTERVAL 1 DAY)