在SQL Server2005/2008中对记录进行分组,并获得每组前N条记录

原创|其它|编辑:郝浩|2009-11-03 10:13:55.000|阅读 443 次

概述:其中km为科目号、kh为考生号、cj为成绩,现对km和kh进行分组,并获得每组前2条记录(按cj从高到低排序)。基本思想是为每组加一个序号列,再用where取序号小于等于2的。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

   假设有一个表,SQL语句如下:

CREATE TABLE [dbo].[scan](
    
[km] [int] NULL,
    
[kh] [int] NULL,
    
[cj] [int] NULL
ON [PRIMARY]


    其中km为科目号、kh为考生号、cj为成绩,现对km和kh进行分组,并获得每组前2条记录(按cj从高到低排序)。基本思想是为每组加一个序号列,再用where取序号小于等于2的。SQL语句如下:

select * from 
(
    
select a.km,a.kh,cj,row_number() over(partition by a.km order by a.km,a.cj desc) n
    
from 
        (
select km,kh,SUM(cj) cj from scan group by km,kh) a 
) b 
where n<=2 order by km, cj desc


最后得到的结果集如下图所示。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:博客园

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP