0

有一张账单清单,我想知道每个客户按 id 分组的销量。每张账单都有一个负责人(一位店员,要么是表中的顾客),所以我想拿起最后一张账单的人并将其包含在结果中。

结果应该是这样的:客户 - 账单总和 - 最后一张账单的负责人。

由于 Oracle 没有“限制”选项(我们还没有 12c),所以我必须使用子选择来完成。这意味着我无法比较客户的 ID,因为它超出了范围(请参阅下面的代码)。欢迎任何建议。

SELECT customer.NAME, SUM(bills.SUME), 
(SELECT responsibleP FROM 
    (SELECT responsibleP FROM bills b WHERE b.responsibleP = customer.id 
    order by asc billDate)
WHERE ROWNUM = 1)
FROM customer, bills
WHERE customer.id = bills.customerid    
GROUP BY customer.id;

在这种情况下,b.responsible无法从 customer 表中获取customer.id 。

请随意更改标题,我不是很擅长,对不起!

4

2 回答 2

9

您应该能够使用MAX( column ) KEEP ( DENSE_RANK [FIRST|LAST] ORDER BY other_columns [ASC|DESC] )来获取一列的最大值,该列也具有另一列的FIRSTLAST值。像这样:

SELECT c.NAME,
       SUM(b.SUME),
       MAX( b.respondibleP ) KEEP ( DENSE_RANK LAST ORDER BY b.billDate )
         AS lastResponsible
FROM customer c
     INNER JOIN bills b
     ON ( c.id = b.customerid )
GROUP BY c.id;
于 2017-11-21T14:31:25.970 回答
0

在 Oracle 中使用KEEP LAST

SELECT
  c.name, 
  SUM(bills.sume), 
  MAX(b.responsibleP) KEEP (DENSE_RANK LAST ORDER BY b.billDate)
FROM customer c
JOIN bills b ON c.id = b.customerid    
GROUP BY c.id;
于 2017-11-21T14:32:45.110 回答