select query MySQL, Beego 中如何选择特定id的总和

我想得到这样的结果


result 

-------------------------------------------------------

id | uuid | user_id |created_date |    amount    | name 

-------------------------------------------------------

1  | ABC  |    1    |   2019/5/1  |      5       | xa

2  | PQR  |    2    |   2019/5/5  |      150     | xb

我尝试使用的查询


SELECT(SELECT SUM(paid_amount) WHERE ID = t1.**HERE**) AS sub1,

(t1.amount - sub1) AS sub2

FROM invoice t1 CROSS JOIN

invoice_paid t2;

我的数据库中的表结构


table invoice_paid        

------------------------------------

id | uuid | paid_date | paid_amount

------------------------------------

1  | ABC  | 2019/5/1  | 15

2  | ABC  | 2019/5/5  | 80 


table invoice

-------------------------------------------------------

id | uuid | user_id |created_date |    amount    | name 

-------------------------------------------------------

1  | ABC  |    1    |   2019/5/1  |      100     | xa

2  | PQR  |    2    |   2019/5/5  |      150     | xb

我只能使用 sum 1 条件,如 where id = 1 但我如何将选择查询中的此查询与连接查询结合起来。我使用 beego(golang),MariaDB


慕容森
浏览 112回答 1
1回答

慕沐林林

您可以使用此查询。它将invoice表连接到派生表SUMs,其中包含每张发票支付的所有金额invoice_paid,从发票金额中减去总计以获得未结金额:SELECT i.id, i.uuid, i.user_id, i.created_date, i.amount - COALESCE(p.amount, 0) AS amount, i.nameFROM invoice iLEFT JOIN (SELECT uuid, SUM(paid_amount) AS amount           FROM invoice_paid           GROUP BY uuid) p ON p.uuid = i.uuidORDER BY i.id输出:id  uuid    user_id created_date        name    amount1   ABC     1       2019-05-01 00:00:00 xa      52   PQR     2       2019-05-05 00:00:00 xb      150
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go