MySQL:获取连接中的计数值以及if else

时间:2013-01-30 10:43:24

标签: mysql sql

在我的应用程序中,我想显示我的所有朋友,而不是给出和接收的支票

Table Transaction                 Table Friends
----------------------------      -----------------------------
id  given_id   rev_id   amt        id  who_id  whom_id  who_name
-----------------------------     -------------------------------
 1    2          1       1k         1     1       2       sss
 2    2          3       1k         2     3       2       fff
 3.   3          2       2k         3     4       1       eee
 4    1          2       2k         4     2       1       iii
-----------------------------      ------------------------------

Result whom_id=2 name=iii  -> Friends (sss,fff) 
                            => sss gives totally 1 cheque and 
                               sss receives totally 1 cheque and
                               fff gives 1 cheque and
                               fff receives 1 cheque and

我试过这个......

SELECT 
p.who_id, 
p.who_name, 
COUNT( r1.give_id ) , 
COUNT( r1.rec_id ) 

FROM 
friends p 
LEFT JOIN Transaction r1 

ON p.who_id = r1.give_id OR p.who_id = r1.rec_id 

WHERE 
p.whom_id = 1 

GROUP BY p.who_id

请为我提供最好的方法....

5 个答案:

答案 0 :(得分:0)

试试这个,

select
  id,
  count(given_id) as given,
  count(rev_id) as reveive
from Friends
GROUP BY id;

如果你想要两个金额之间的差异,试试这个

select
  id,
  count(given_id) as given,
  count(rev_id) as reveive,
  given-receive as diff
from Friends
GROUP BY id;

答案 1 :(得分:0)

您可以在分组中使用HAVING, 代替

WHERE p.whom_id = 1 

答案 2 :(得分:0)

有两种方法可以做到这一点,都涉及两次加入Transactions表。

您可以使用子查询:

SELECT f.who_id,
  f.who_name,
  t1.TotalGiven,
  t2.TotalRev
FROM friends f
LEFT JOIN
(
  select count(t.given_id) TotalGiven, t.given_id
  from Transactions t
  group by t.given_id
) t1
  ON f.who_id = t1.given_id 
LEFT JOIN
(
  select count(t.rev_id) TotalRev, t.rev_id
  from Transactions t
  group by t.rev_id
) t2
  ON f.who_id = t2.rev_id 
where f.whom_id = 2;

请参阅SQL Fiddle with Demo

或者你可以使用没有子查询的连接:

select f.who_id,
  f.who_name,
  count(t1.given_id) TotalGiven,
  count(t2.rev_id) TotalRev
FROM friends f
LEFT JOIN Transactions t1
  ON f.who_id = t1.given_id 
LEFT JOIN Transactions t2
  ON f.who_id = t2.rev_id 
where f.whom_id = 2
group by f.who_id,  f.who_name

请参阅SQL Fiddle with Demo

答案 3 :(得分:0)

你可以这样做

SELECT
  f.who_name,
  count(t.given_id)    GivenTotal,
  count(lt.rev_id) as RecievedTotal
from friends as f
  left join transaction as t
    on t.given_id = f.who_id
  left join transaction as lt
    on lt.rev_id   = f.who_id    
where f.whom_id = 2
group by t.given_id

Demo

输出

who_name | GivenTotal | RecievedTotal 
----------------------------------
sss      |  1         |     1 
fff      |  1         |     1 

答案 4 :(得分:0)

最后我得到了答案,

SELECT 
p.who_id, p.who_name, COUNT( r1.give_id ) , COUNT( r2.rec_id ) 

FROM 
friends p 
LEFT JOIN Transaction r1  ON p.who_id = r1.give_id 
LEFT JOIN Transaction r2  on p.who_id = r2.rec_id
WHERE 
p.whom_id = 1 

GROUP BY p.who_id