sqlserver中分区函数partitionby的⽤法
需求场景:
表结构及数据:
查询效果:
思路:
sql语句:
查询结果:
=========================感谢下⾯这些博主的博客=============================
转⾃:
partition by关键字是分析性函数的⼀部分,它和聚合函数(如group by)不同的地⽅在于它能返回⼀个分组中的多条记录,⽽聚合函数⼀般只有⼀条反映统计值的记录,
partition by⽤于给结果集分组,如果没有指定那么它把整个结果集作为⼀个分组。
partition by 与group by不同之处在于前者返回的是分组⾥的每⼀条数据,并且可以对分组数据进⾏排序操作。后者只能返回聚合之后的组的数据统计值的记录。
Demo
数据库表结构学⽣成绩表 UserGrade
Id int Checked 主键Id
Name varchar(50) Checked 学⽣名
Course varchar(50) Checked 课程名
Score int Checked 分数
01、把每个⼈学⽣的成绩按照升序排名(思路:根据学⽣姓名分组根据每个⼈成绩排序)
sql语句
select *,ROW_NUMBER() over( partition by Name order by Score )排名
from UserGrade
查询结果
Id Name Course Score 排名
1004 李四数学 60 1
1005 李四语⽂ 80 2
1001 李四英语 100 3
1007 王五数学 30 1
1006 王五语⽂ 50 2
1003 王五英语 50 3
1008 张三英语 60 1
1000 张三语⽂ 80 2
1002 张三数学 90 3
02、把每个学科的成绩分别进⾏排名(思路:根据学科分组根据成绩排序)
sql语句
select *,ROW_NUMBER() over( partition by Course order by Score )排名from UserGrade
查询结果
Id Name Course Score 排名
1002 张三数学 90 1
1004 李四数学 60 2
1007 王五数学 30 3
group by的用法及原理详解1001 李四英语 100 1
1008 张三英语 60 2
1003 王五英语 50 3
1000 张三语⽂ 80 1
1005 李四语⽂ 80 2
1006 王五语⽂ 50 3
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论