1

我有桌子水果:

|ID|FruitName|
|1 |Banana   |
|2 |Orange   |
|3 |Apple    |

我也有销售表:

|ID|Month|Sold|
|1 |Jan  |20  |
|1 |Feb  |10  |
|1 |Mar  |30  |
|2 |Apr  |15  |
|2 |Jan  |25  |
|3 |Jul  |25  |
|3 |Jun  |18  |

现在我想显示这个

1|Banana|Mar|30|
2|Orange|Jan|25|
3|Apple |Jul|25|
4

5 回答 5

1

您需要将fruit表加入sales一次以获取月份,然后再次加入sales表以获取maxSold计数,您可以使用该计数过滤掉sold计数不等于maxSold.

SELECT  f.id, f.name, s.month, maxSold
FROM fruit f LEFT JOIN sales s ON f.id = s.id 
      LEFT OUTER JOIN 
        (SELECT id,  max(sold) maxSold FROM sales 
             GROUP BY id) salesMax ON salesMax.id = f.id
WHERE s.sold = maxSold

演示

于 2013-09-12T03:53:08.907 回答
0

尝试这个:

SELECT f.id
    ,f.fruitname
    ,s.month
    ,s.sold

FROM fruits f
LEFT JOIN (SELECT a.*
    FROM Sales a LEFT JOIN Sales b ON a.Id = b.IdAND a.Sold < b.sold
    WHERE b.Sold IS NULL) AS s 
ON s.id = f.id

销售表之间的内左连接正在获取最大值,然后外左连接只是添加水果名称。

于 2013-09-12T03:58:24.993 回答
0

尝试这个:

select a.id, a.month, a.sold, c.fruitName
from   sales a,
       (
         select month, max(sold) sold
         from   sales
         group by month
       ) b,
       fruits c
where  a.month = b.month AND a.sold = b.sold AND a.id = c.id
于 2013-09-12T04:20:43.977 回答
-1

您可能不需要 distinct ,但这对于 MySQL 来说应该有点接近。

SELECT DISTINCT
    F.ID
    , F.FruitName
    , M.Month
    , MAX(M.Sold) AS Sold
FROM 
    Fruits F
JOIN
    Sales S ON
    F.ID = S.ID
GROUP BY F.ID, F.FruitName, M.Month, M.Sold
于 2013-09-12T03:11:13.877 回答
-1

我可以在我的 SQL 语句中这样做。

SELECT
 fruits.ID,
 fruits.FruitName,
 Sales.Month,
 MAX(Sales.Sold) as MAX
FROM
 fruits
LEFT JOIN Sales
 ON fruits.ID = Sales.id
GROUP BY 
fruits.id
于 2013-09-12T03:15:21.057 回答