栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

按另一列选择具有最大列值的行组

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

按另一列选择具有最大列值的行组

我本人为此进行了很多次努力,解决方案是以不同的方式考虑您的查询。

我希望其中具有该DocGroupViewID的所有行的Del_Index是最高(最大)的每个DocGroupViewID行:

SELECt    T.DocGroupViewID,    T.Del_Index,    T.IDFROM MyTable TWHERe T.Del_Index = (    SELECt MAX( T1.Del_Index ) FROM MyTable T1    WHERe T1.DocGroupViewID = T.DocGroupViewID )

当多个行可以具有相同的行时,它将变得更加复杂

Del_Index
,因为从那时起,您需要某种方式来选择要显示的行。


编辑:想跟进另一种选择

您可以将

RANK()
ROW_NUMBER()
函数与CTE结合使用,以更好地控制结果,如下所示:

-- fake a source tableDECLARE @t TABLE (    ID int IDENTITY(1,1) PRIMARY KEY,    Del_Index int,    DocGroupViewID int)INSERT INTO @tSELECt 1, 1 UNIOn ALLSELECT 2, 1 UNIOn ALLSELECT 3, 1 UNIOn ALLSELECT 1, 2 UNIOn ALLSELECT 2, 2 UNIOn ALLSELECT 2, 2 UNIOn ALLSELECT 1, 3 UNIOn ALLSELECT 2, 3 UNIOn ALLSELECT 3, 3 UNIOn ALLSELECT 4, 3-- show our sourceSELECT * FROM @t-- select using RANK (can have duplicates);WITH cteRank AS(    SELECT        DocGroupViewID,        Del_Index,        ID,        RANK() OVER (PARTITION BY DocGroupViewID ORDER BY Del_Index DESC)        AS RowRank,        ROW_NUMBER() OVER (PARTITION BY DocGroupViewID ORDER BY Del_Index DESC)        AS RowNumber    FROM @t)SELECt *FROM cteRankWHERe RowRank = 1-- select using ROW_NUMBER;WITH cteRowNumber AS(    SELECT        DocGroupViewID,        Del_Index,        ID,        RANK() OVER (PARTITION BY DocGroupViewID ORDER BY Del_Index DESC)        AS RowRank,        ROW_NUMBER() OVER (PARTITION BY DocGroupViewID ORDER BY Del_Index DESC)        AS RowNumber    FROM @t)SELECt *FROM cteRowNumberWHERe RowNumber = 1

如果您有办法解决领带,只需将其添加到中

ORDER BY



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/415277.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号