作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在使用子查询的结果连接到主表之前,我需要对属于子查询中某个 ID 的所有值求和。例如:
Table A
ID | Site
1 | TX
2 | NY
Table B
ID | Cost
1 | 10
1 | 2
1 | 8
2 | 3
2 | 7
Select A.Site, B.Cost
from A
Left join (select distinct ID, Cost from B) as B
on A.ID = B.ID
Group by A.Site;
该表的结果是:
Site | Cost
TX | 10
NY | 3
应该是
Site | Cost
TX | 20
NY | 10
看来我的子查询并没有提取属于每个不同 B.ID 的所有成本 - 因此我的联接仅带来第一个成本记录,而不是每个 B.ID 每个成本记录的总和
在将子查询连接到主表之前,如何对子查询中的所有成本求和?我需要使用子查询,因为我的 ID 是一对多,而且我的表很大,所以如果我只是连接两个表,查询将永远进行。
谢谢!
最佳答案
听起来这可以通过子查询来解决
Select
A.Site,
(SELECT SUM(B.Cost) FROM B WHERE B.Id = A.Id) as `Cost`
FROM A;
关于mysql - 在加入主表之前对子查询中的多对一元素求和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45992167/
我是一名优秀的程序员,十分优秀!