如何按两个字段计数并与其他 table Postgres 连接?

How to count by two fields and join with other table Postgres?

我有两个 table,一个 table 用户和第二个 table 与用户完成的交易相关的交易。我想做一个查询,按名称和日期给我计数,用户 table 中的字段。我该怎么做?

Table user:

Name   Id Card
-----------------
Alex   01  N
James  02  Y


Table transaction:

Name   Date
-----------------
Alex   01/07/2012
Alex   01/12/2012
James  01/08/2012
Alex   01/07/2012
Alex   01/12/2012
James  01/07/2012
James  01/07/2012

我想要这样的东西:

Name   Date         Transactions    ID   Card
---------------------------------------------
Alex   01/07/2012   2               01   N
Alex   01/12/2012   2               01   N
James  01/08/2012   1               02   Y 
James  01/07/2012   2               02   Y

首先,我尝试用这样的两列来计算:

select name, date, count(name, date) from pm_transaction GROUP BY (name,date)
select count(distinct(machine, date)) from pm_transaction

但是还是不行,我试了很多组合都没用

试试这个

select tb1.name, tb2.date , tb2.transaction , tb1.Id, tb1.card from tbUser as tb1 inner join (select date, name, count(date) as transaction from tbTransaction group by date) as tb2 on tb1.name = tb2.name

这看起来像是简单的聚合任务。只需检查并更正 table 连接条件和 table 名称:

select u.name, t.date, count(1) as transactions, u.id, u.card
from transaction t
join user_table u on u.name = t.name
group by u.name, t.date, u.id, u.card;