[英]SELECT TOP 2 MAX Value Group By SQL
我有下表:
-----------------------------------------
xDate xItem xCount
-----------------------------------------
2018-01-01 A 100
2018-01-01 B 200
2018-01-01 D 500
2018-01-02 C 200
2018-01-02 E 800
我想在xCount字段的MAX值上為每個日期選擇TOP 2值。 因此,結果應為:
-----------------------------------------
xDate xItem xCount
-----------------------------------------
2018-01-01 D 500
2018-01-01 B 200
2018-01-02 E 800
2018-01-02 C 200
有人對此案有想法嗎?
干杯,
您可以嘗試使用RANK
窗口函數,如果兩行中的xCount
相同,則您希望全部獲取它們。
您可以嘗試使用dense_rank
而不是RANK
SELECT xDate,xItem,xCount
FROM (
SELECT *,RANK() OVER(PARTITION BY xDate ORDER BY xCount DESC) rn
FROM T
) t1
WHERE t1.rn <= 2
您可以使用ROW_NUMBER()
並根據xDate
對其進行分區, xDate
進行xCount
以獲取所需的內容。
select X.xDate,
X.xItem,
X.xCount
from
(select xDate,
xItem,
xCount,
row_number() over (partition by xDate order by xCount desc) rank_of_count
from table_name) X
where rank_of_count < 3
好吧,我不會使用任何功能。 對我來說看起來很直白。 最快的是
SELECT * FROM #temp s
WHERE ( SELECT COUNT(*) FROM #temp f WHERE f.xDate = s.xDate AND f.xCount >= s.xCount ) <= 2
Order by xDate, xCount desc
在此處檢查完整的示例代碼:
create table #temp (xDate datetime, xItem nvarchar(max), xCount int);
insert into #temp
select
'2018-01-01','A', 100 union all
select '2018-01-01','B', 200 union all
select '2018-01-01','D', 500 union all
select '2018-01-02','C', 200 union all
select '2018-01-02','E', 800
SELECT * FROM #temp s
WHERE ( SELECT COUNT(*) FROM #temp f WHERE f.xDate = s.xDate AND f.xCount >= s.xCount ) <= 2
Order by xDate, xCount desc
drop table #temp;
另一種方法是使用TOP,CROSS APPLY。
;WITH CTE AS
(
select
distinct xDate
from Your_Table
)
SELECT
T.xDate,
T1.xItem,
T1.xCount
FROM CTE T
CROSS APPLY (SELECT TOP 2 xItem,xCount FROM Your_Table WHERE xDate=T.xDate ORDER BY xCount DESC ) T1
另一個使用DENSE_RANK()
建議:
DECLARE @FooTable TABLE
(
xDate VARCHAR(25),
xItem VARCHAR(10),
xCount INT
)
INSERT INTO @FooTable
(
xDate,
xItem,
xCount
)
VALUES
('2018-01-01', 'A', 100)
, ('2018-01-01', 'B', 200)
, ('2018-01-01', 'D', 500)
, ('2018-01-02', 'C', 200)
, ('2018-01-02', 'E', 800)
SELECT
s.*
FROM
(
SELECT
ft.xDate
, ft.xItem
, ft.xCount
--, ROW_NUMBER() OVER(PARTITION BY ft.xDate ORDER BY ft.xCount DESC) rn
, DENSE_RANK() OVER (PARTITION BY ft.xDate ORDER BY ft.xCount desc) dr
FROM @FooTable ft
)s
WHERE s.dr < 3
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.