在MySQL中按列值进行SUM

问题描述 投票:-1回答:1

我有这个表“a”:

ID | NUMORD | ITEMID
---------------------
1  |   1    |  4
2  |   1    |  5
3  |   1    |  6

而不是这个表“b”

ID | NUMORD | ITEMID | QT
--------------------------
1  |   1    |  4     | 2
2  |   1    |  4     | 1
3  |   1    |  5     | 3
4  |   1    |  6     | 1
5  |   1    |  5     | 2

我需要这样的结果:

ID | NUMORD | ITEMID | QT
--------------------------
1  |   1    |  4     | 3
2  |   1    |  5     | 5
3  |   1    |  6     | 1

如果我按第一个表上的NUMORD分组然后按SUM,则显示SUM OF“QT”。我怎么能得到我的结果?谢谢

mysql sum
1个回答
0
投票

首先,你需要NUMORD和ITEMID的一些:

SELECT NUMORD,ITEMID, SUM(QT)
FROM tableB
GROUP BY NUMORD,ITEMID

然后使用JOIN:

SELECT a.ID, b.NUMORD, b.ITEMID, b.QT
FROM tableA a
INNER JOIN (
 SELECT NUMORD,ITEMID, SUM(QT)
 FROM tableB
 GROUP BY NUMORD,ITEMID
) AS b ON b.NUMORD = a.NUMORD AND b.ITEMID = a.ITEMID

NOTA:您的数据库模式似乎有点奇怪为什么2个表具有几乎相同的列?

© www.soinside.com 2019 - 2024. All rights reserved.