sql - Postgres 计算 GROUP BY 中的唯一结果

标签 sql postgresql group-by

我有一张 table :

id | parent_id  |    create_time  
---|------------|--------------------  
1  |     1      | 2016-08-26 00:00:00  
2  |     2      | 2016-08-24 00:00:00  
3  |     2      | 2016-08-22 00:00:00  
4  |     4      | 2016-07-26 00:00:00  
5  |     5      | 2016-07-24 00:00:00

我需要计算每个月(周、日)的唯一“parent_id”。
输出类似这样的内容:

---------------------|----  
2016-08-01 00:00:00  |  2  
2016-07-01 00:00:00  |  2

但我只能这样做:

SELECT date_trunc('month', create_time),count(parent_id) FROM test GROUP BY
date_trunc('month', create_time),parent_id

结果:

--------------------|---
2016-07-01 00:00:00 | 1
2016-07-01 00:00:00 | 1
2016-08-01 00:00:00 | 1
2016-08-01 00:00:00 | 2

我尝试了很多选择,但没有足够的知识。

最佳答案

您需要从 group by 子句中删除 parent_id。您可能还想使用 count(distinctparent_id) :

SELECT date_trunc('month', create_time),
       count(distinct parent_id) 
FROM test 
GROUP BY date_trunc('month', create_time)

关于sql - Postgres 计算 GROUP BY 中的唯一结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39226184/

相关文章:

mysql - mariadb sql 默认 unix_timestamp

java - 存储过程调用期间使用 CallableStatement 的 SQL 语句无效

sql - PostgreSQL upper function on the ascii 152 character ("ÿ")

mysql group by uid 哪个uid与另一个查询匹配

sql - @value 和 FLOOR(@value) 的差值对于 DECIMAL 类型为 0

sql - 单元测试你的 SQL 是否把 TDD 做得太过分了?

c# - PostgreSQL 日期 C# DateTime

java - 组织.postgresql.util.PSQLException : ERROR: syntax error at or near "$1"

python - 我如何按值分组?

Mysql - 可以使用 Group By semester 吗?