首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >连接表时将SUM作为条件

连接表时将SUM作为条件
EN

Stack Overflow用户
提问于 2017-05-15 22:36:40
回答 2查看 116关注 0票数 0

我有这个查询,它计算我每月收到的退货发票数量:

代码语言:javascript
复制
SELECT MONTH(ORIN.DocDate) mes, COUNT(*) tot
FROM ORIN
WHERE DATEDIFF(MONTH, ORIN.DocDate, GETDATE()) <= 12
GROUP BY MONTH(ORIN.DocDate)

现在我只需要获取商品数量超过100的发票。为此,我必须连接另一个表(发票项):

代码语言:javascript
复制
INNER JOIN RIN1 ON ORIN.DocEntry = RIN1.DocEntry

我会把它放在某个地方(必须是一个总和,因为一张发票可以有很多项):

代码语言:javascript
复制
WHERE SUM(RIN1.Quantity) > 100

问题是我不知道如何进行这个查询。我的最后一次尝试如下所示,但它没有带来正确的值:

代码语言:javascript
复制
SELECT MONTH(ORIN.DocDate) mes, COUNT(*) tot
FROM ORIN
INNER JOIN RIN1 ON ORIN.DocEntry = RIN1.DocEntry
WHERE DATEDIFF(MONTH, ORIN.DocDate, GETDATE()) <= 12
GROUP BY MONTH(ORIN.DocDate)
HAVING SUM(RIN1.Quantity) > 100
EN

回答 2

Stack Overflow用户

发布于 2017-05-15 23:25:14

您只需要考虑存在超过100个项目的发票。有两种方法:

1)计算具有相关子查询的项目:

代码语言:javascript
复制
select month(docdate) mes, count(*) tot
from orin
where datediff(month, docdate, getdate()) <= 12
and 
(
  select sum(quantity)
  from rin1
  where rin1.docentry = orin.docentry
) > 100
group by month(docdate);

2)查询100条以上的发票列表:

代码语言:javascript
复制
select month(docdate) mes, count(*) tot
from orin
where datediff(month, docdate, getdate()) <= 12
and docentry in
(
  select docentry
  from rin1
  group by docentry
  having sum(quantity) > 100
)
group by month(docdate);
票数 1
EN

Stack Overflow用户

发布于 2017-05-15 22:41:54

您希望筛选包含超过100个项目的发票,如RIN1.Quantity所示。

只需在WHERE中添加过滤器

代码语言:javascript
复制
SELECT MONTH(ORIN.DocDate) mes, COUNT(*) tot
FROM ORIN
INNER JOIN RIN1 ON ORIN.DocEntry = RIN1.DocEntry
WHERE DATEDIFF(MONTH, ORIN.DocDate, GETDATE()) <= 12
  AND RIN1.Quantity > 100
GROUP BY MONTH(ORIN.DocDate)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43982246

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档