亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

select query MySQL, Beego 中如何選擇特定id的總和

select query MySQL, Beego 中如何選擇特定id的總和

Go
慕容森 2023-06-19 15:15:32
我想得到這樣的結果result -------------------------------------------------------id | uuid | user_id |created_date |    amount    | name -------------------------------------------------------1  | ABC  |    1    |   2019/5/1  |      5       | xa2  | PQR  |    2    |   2019/5/5  |      150     | xb我嘗試使用的查詢SELECT(SELECT SUM(paid_amount) WHERE ID = t1.**HERE**) AS sub1,(t1.amount - sub1) AS sub2FROM invoice t1 CROSS JOINinvoice_paid t2;我的數據庫中的表結構table invoice_paid        ------------------------------------id | uuid | paid_date | paid_amount------------------------------------1  | ABC  | 2019/5/1  | 152  | ABC  | 2019/5/5  | 80 table invoice-------------------------------------------------------id | uuid | user_id |created_date |    amount    | name -------------------------------------------------------1  | ABC  |    1    |   2019/5/1  |      100     | xa2  | PQR  |    2    |   2019/5/5  |      150     | xb我只能使用 sum 1 條件,如 where id = 1 但我如何將選擇查詢中的此查詢與連接查詢結合起來。我使用 beego(golang),MariaDB
查看完整描述

1 回答

?
慕沐林林

TA貢獻2016條經驗 獲得超9個贊

您可以使用此查詢。它將invoice表連接到派生表SUMs,其中包含每張發票支付的所有金額invoice_paid,從發票金額中減去總計以獲得未結金額:


SELECT i.id, i.uuid, i.user_id, i.created_date, i.amount - COALESCE(p.amount, 0) AS amount, i.name

FROM invoice i

LEFT JOIN (SELECT uuid, SUM(paid_amount) AS amount

? ? ? ? ? ?FROM invoice_paid

? ? ? ? ? ?GROUP BY uuid) p ON p.uuid = i.uuid

ORDER BY i.id

輸出:


id? uuid? ? user_id created_date? ? ? ? name? ? amount

1? ?ABC? ? ?1? ? ? ?2019-05-01 00:00:00 xa? ? ? 5

2? ?PQR? ? ?2? ? ? ?2019-05-05 00:00:00 xb? ? ? 150

查看完整回答
反對 回復 2023-06-19
  • 1 回答
  • 0 關注
  • 144 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號