我有这个表“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”。我怎么能得到我的结果?谢谢
首先,你需要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个表具有几乎相同的列?