假设我有 3 行数据:
id product_uuid version_uuid created_at
22 586d8e21b9529d14801b91bd 5a711a0094df04e23833d8ef 2018-02-10 19:51:15.075-05
23 586d8e21b9529d14801b91bd 5a711a0094df04e23833d8ef 2018-02-10 19:51:16.077-07
24 586d8e21b9529d14801b91bd 5a711a0094df04e23833d8ef 2018-02-11 19:51:15.077-05
我想通过 created_at
列按天对它们进行分组。
SELECT created_at::date, COUNT(*)
FROM table_name
WHERE product_uuid = '586d8e21b9529d14801b91bd'
AND created_at > now() - interval '30 days'
GROUP BY created_at
ORDER BY created_at ASC
我希望这会产生 2 行:
created_at count
2018-02-10 2
2018-02-11 1
但我实际上得到了 3 行:
created_at count
2018-02-10 1
2018-02-10 1
2018-02-11 1
我意识到 GROUP BY
仍然按细粒度时间戳分组,但我不确定如何让 Postgres 使用截断日期。
最佳答案
您还需要在 GROUP BY
中进行截断:
SELECT created_at::date, COUNT(*)
FROM table_name
WHERE product_uuid = '586d8e21b9529d14801b91bd' AND
created_at > now() - interval '30 days'
GROUP BY created_at::date
ORDER BY created_at::date ASC;
您的版本按每个日期/时间值聚合,但只显示日期部分。
此外,我建议您使用 current_date
而不是 now()
,这样第一个日期就不会被截断。
关于sql - 如何在 Postgres 中使用时间戳字段按日期分组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48841591/