Re: Помогите с запросом

From
Dmitry Novikov (2:5020/400)
To
andrew blinov
Date
2005-12-06T11:38:18Z
Area
SU.DBMS.SQL
From: "Dmitry Novikov" <dim@rnivc.kis.ru>

Всем привет!

"andrew blinov" сообщил/сообщила в новостях следующее:
> Есть таблица, сколько в каком магазине какого товара продано. Как выбрать самый популярный товар (чаще покупаемый) в каждом
магазине?
>
> ID_SALE ID_SHOP SALE_RES ID_GOOD
> 1       1       1        1
> 2       1       2        2
> 3       2       4        4
> 4       3       2        4
> 5       1       5        1
>
> Нужно получить:
>
> ID_SHOP SALES    ID_GOOD
> 1       6        1
> 2       4        4
> 3       2        4
>
> SELECT ID_SHOP, ID_GOODS, SUM(SALE_RES) as SALES
>            FROM SALES GROUP BY ID_SHOP, ID_GOODS
>
> А вот как теперь отсеять только максимальные по магазинам?

Что-то вроде такого:
select a.* from
(SELECT ID_SHOP, ID_GOOD, SUM(SALE_RES) as SALES
FROM SALES GROUP BY ID_SHOP, ID_GOOD
) a
join
(
 select ID_SHOP, max(SALES) SALES from
 (SELECT ID_SHOP, ID_GOOD, SUM(SALE_RES) as SALES
 FROM SALES GROUP BY ID_SHOP, ID_GOOD
 ) b group by ID_SHOP
) c on c.ID_SHOP = a.ID_SHOP and c.SALES = a.SALES

Можно еще так извратиться, но это наверное хуже:
SELECT ID_SHOP, ID_GOOD, SUM(SALE_RES) as SALES
FROM SALES a GROUP BY ID_SHOP, ID_GOOD
having SUM(SALE_RES) =
(select top 1 sum(sale_res) from sales b where b.ID_SHOP = a.ID_SHOP
GROUP BY ID_SHOP, ID_GOOD order by sum(sale_res) desc)

С наилучшими пожеланиями, Дмитрий.
dim_nУБРАТЬrnivcРУССКИЕkisБУКВЫru



--- ifmail v.2.15dev5.3
 * Origin: Demos online service (2:5020/400)
SEEN-BY: 46/50 50/12 203 520 450/159 186 1024 451/30 454/9 461/43 132 640
SEEN-BY: 469/999 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001
SEEN-BY: 5006/1 5007/1 5010/53 70 5011/13 5012/23 46 5015/10 28 5019/31
SEEN-BY: 5020/86 118 175 194 400 545 604 639 715 758 830 892 982 1042 1057
SEEN-BY: 5020/1200 1523 1604 1665 1909 1922 2013 2020 2238 4441 5021/3 29
SEEN-BY: 5022/128 5025/3 750 5026/10 14 45 5027/16 5029/32 5030/115 217 436
SEEN-BY: 5030/473 556 966 1063 1339 1900 5035/38 5036/1 34 5040/47 5042/13
SEEN-BY: 5045/7 5047/43 47 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67
SEEN-BY: 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 5066/18 5069/7 5070/1222
SEEN-BY: 5077/70 5080/68 1003 5081/2 5082/6 5083/21 5084/32 5085/13 5090/106
SEEN-BY: 5093/27 5095/20 5099/133 6000/12 254 6009/1
PATH: 5020/400 4441 545 5054/1 37