首页 文章

来自两个mysql表列的总和

提问于
浏览
1

我有两个mysql表:

table: loan
--------------------------------------------------------
 id | advance_id | loan_amount | deposit_amount | date
--------------------------------------------------------
 1 | 22556678 | 5000 | 0 | 2015-02-06
 2 | 22556678 | 5000 | 0 | 2015-02-07
--------------------------------------------------------

table: advance
--------------------------------------------------------
id | advance_id | advance_amount | purpose | date
--------------------------------------------------------
 1 | 22556678 | 20000 | purchase | 2015-01-30
 2 | 22556678 | 10000 | purchase | 2015-01-31

我希望从表中获得'loan_amount'的总和:loan和表中的'advance_amount'的总和:在INNER JOIN加入的一个mysql查询中前进 .

如何从两个表的列中获得总和?

SELECT 
  a.advance_id,
  SUM(a.advance_amount) AS adv_amount,
  a.purpose,
  a.date,
  SUM(l.loan_amount) AS loan_amount 
FROM
  advance AS a 
  INNER JOIN loan AS l 
    ON a.advance_id = l.advance_id 
GROUP BY a.advance_id 
HAVING SUM(l.loan_amount) - SUM(l.deposit_amount) > 0

1 回答

  • 2

    你可以重写你的查询

    SELECT 
      a.advance_id,
      SUM(a.advance_amount) AS adv_amount,
      a.purpose,
      a.date,
      l.loan_amount 
    FROM
      advance AS a 
      INNER JOIN 
      (
        SELECT advance_id,SUM(deposit_amount) AS loan_amount
        FROM loan
        GROUP BY advance_id
        HAVING SUM(loan_amount) - SUM(deposit_amount) > 0 
      )  AS l USING(advance_id)
    GROUP BY a.advance_id
    

    DEMO

相关问题