14

我正在尝试使用此查询获取 2 小时或更长时间的所有记录:

$minutes = 60 * 2

SELECT COUNT(id) AS TOTAL, job_id 
  from tlb_stats 
 WHERE log_time >= DATE_SUB(CURRENT_DATE, INTERVAL $minutes MINUTE) 
GROUP BY job_id

它只选择最近的记录并跳过旧的。当我更改log_time <= ...它时,它只选择旧的并跳过新的。

我究竟做错了什么?

4

3 回答 3

24

尝试:

$minutes = 60 * 2

SELECT COUNT(`id`) AS `TOTAL`, `job_id` 
  FROM `tlb_stats` 
  WHERE `log_time` < DATE_SUB(NOW(), INTERVAL $minutes MINUTE) 
  GROUP BY `job_id`
  • 使用反引号来引用字段(像“total”和“id”这样的词有一天可能在 MySQL 中意味着什么)
  • 用于NOW()CURRENT_DATE 仅表示 2010-08-04,不包括时间
  • 用于<获取于该日期的条目。
于 2010-08-04T00:09:29.170 回答
1
SELECT * FROM `table_name` WHERE CURTIME() >= (`colname` + INTERVAL 120 MINUTE)

这里,colname是您在创建记录时添加时间戳的列。

于 2015-03-07T10:20:23.660 回答
0

你也可以这样做:

$minutes = 60 * 2

SELECT COUNT(`id`) AS `TOTAL`,
       `job_id` 
FROM `tlb_stats` 
WHERE `log_time` < NOW() - INTERVAL $minutes MINUTE
GROUP BY `job_id`
于 2019-04-24T22:18:56.583 回答