尝试从 SQL 获取 24 小时的数据

Trying to get 24 hours of data from SQL

我不是很擅长 SQL 所以希望这里有人能帮助我。

我的 table 中有一个 date_of_post 列,看起来像这样(示例)2015-08-31 11:00:00.

我使用 INTERVAL 1 DAY 获取最近 24 小时。然而,它似乎比过去 24 小时多了 return。这是我用来获取数据的查询

SELECT DATE_ADD(date(t.date_of_post),
       INTERVAL hour(t.date_of_post) HOUR) AS dateTime,
       count(*) as entries 
FROM `soc_stat` t 
WHERE `main_tag` = 'morgenmad' 
  AND t.date_of_post > DATE_SUB(CURDATE(), INTERVAL 1 DAY) 
GROUP BY date(t.date_of_post), hour(t.date_of_post)

它 return 如下:

2015-08-31 11:00:00 = 11
2015-08-31 12:00:00 = 2
2015-08-31 13:00:00 = 3
2015-08-31 14:00:00 = 3
2015-08-31 15:00:00 = 1
2015-08-31 16:00:00 = 3
2015-08-31 17:00:00 = 2
2015-08-31 19:00:00 = 1
2015-09-01 04:00:00 = 1
2015-09-01 05:00:00 = 3
2015-09-01 06:00:00 = 9
2015-09-01 07:00:00 = 33
2015-09-01 08:00:00 = 38
2015-09-01 09:00:00 = 29
2015-09-01 10:00:00 = 13
2015-09-01 11:00:00 = 12
2015-09-01 12:00:00 = 6
2015-09-01 13:00:00 = 5

我不明白为什么11:00:0012:00:0013:00:00存在于2015-08-312015-09-01中。不应该只 return 最后 24 小时吗?

CURDATE()returns"beginning of today"。将其替换为 NOW()

视觉效果可能会有所帮助。如果您使用别名,请始终使用它们。当您使用计数等聚合函数时,按所有非聚合列分组。

for me it is 2015-09-01 08:47:00

create table soc_stat
(   id int auto_increment primary key,
    main_tag varchar(20) not null,
    date_of_post datetime not null
);
truncate table soc_stat;
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-09-02 11:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-09-01 11:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-09-01 09:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-09-01 08:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-09-01 07:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-08-31 09:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-08-31 08:00:00');
insert soc_stat (main_tag,date_of_post) values  ('morgenmad','2015-08-31 07:00:00');

SELECT date(t.date_of_post) dt, hour(t.date_of_post) hr,count(*) as entries 
FROM `soc_stat` t  
WHERE t.`main_tag` = 'morgenmad'  
AND t.date_of_post between DATE_SUB(now(), INTERVAL 1 DAY) and now() 
GROUP BY dt,hr 
order by t.date_of_post desc;

+------------+------+---------+
| dt         | hr   | entries |
+------------+------+---------+
| 2015-09-01 |    8 |       1 |
| 2015-09-01 |    7 |       1 |
| 2015-08-31 |    9 |       1 |
+------------+------+---------+