首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >共享联合中的行-分组依据?

共享联合中的行-分组依据?
EN

Stack Overflow用户
提问于 2013-05-10 01:45:41
回答 1查看 46关注 0票数 2

我有一个类似这样的查询:

代码语言:javascript
复制
SELECT * FROM (
   SELECT id, SUM( orderLineTotal ) as orderLine1, NULL as orderLine 2
   FROM Orders
   WHERE Orders.Date < @Today
   GROUP BY id

   UNION

   SELECT id, NULL as orderLine1, SUM(orderLineTotal2) as orderLine 2
   FROM Orders
   WHERE Orders.Date = @Today
   GROUP BY id
) o
GROUP BY o.id, o.orderLine1, o.orderLine2

我得到的结果如下:

代码语言:javascript
复制
 ID         OrderLine1          OrderLine2
 -----------------------------------------
 1          105.00              NULL
 1          NULL                204.00
 2          49.30               NULL
 2          NULL                94.24

有没有办法修改查询以返回类似下面这样的结果?

代码语言:javascript
复制
 ID         OrderLine1          OrderLine2
 -----------------------------------------
 1          105.00              204.00
 2          49.30                94.24
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-10 01:54:25

您希望使用一个查询和条件聚合来完成此操作:

代码语言:javascript
复制
   SELECT id,
          SUM(case when Orders.Date < @Today then orderLineTotal end) as orderLine1, 
          SUM(case when Orders.Date = @Today then orderLineTotal2 end) as orderLine2
   FROM Orders
   GROUP BY id

顺便问一下,真的有两列,orderLineTotalorderLineTotal2吗?我怀疑只有一个,第二个sum()应该相应地改变。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16467884

复制
相关文章

相似问题

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