惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 风清云淡

Extjs使用 RestfulWebApi +Token验证小结 Oracle 10g的备份与还原 如何通过反射动态调用泛型方法 Oracle与Sql Server写SQL的区别 Oracle 表与字段的注释操作 将MS SQL SERVER 数据库导入到ORACLE的坑 SQL SERVER 触发器的误区 Asp.net Core部署于CentOS上报404错误的坑 SqlBulkCopy 来自数据源的 String 类型的给定值不能转换为指定目标列的类型 bit CefSharp"Could not load file or assembly 'CefSharp.Core.dll' or one of its dependencies" - 风清云淡 在同一个项中引用同一类库的多个版本 - 风清云淡 Visual Studio中Js使用智能感知 - 风清云淡 Func<T>,Action<T>,Predicate<T>使用小结 Nuget 在VS中操作命令 Unity的动态加载简单使用 枚举的使用总结 IIS WEB程序如何访问共享目录 AngularJS之页面跳转Route ASP.NET MVC4 BundleConfig的注意事项
SQL SERVER OVER开窗函数,Partition By,ROW_NUMBER(),DENSE_RANK(),RANK()排名函数
风清云淡 · 2017-04-24 · via 博客园 - 风清云淡

OVER 子句定义查询结果集内的窗口或用户指定的行集

Partition  By用于给结果集分组,在OVER子句中使用

1.OVER()函数可配合排名函数(ROW_NUMBER,DENSE_RANK,RANK)产生排名结果集

2.OVER()函数可配合聚合函数,使每个行集得到统计列

示例用法如下

--DROP TABLE #Student
CREATE TABLE #Student  --学生语文成绩表
(
 id INT,  --主键
 Student VARCHAR(20),--学号
 Class VARCHAR(20), --班级
 Score INT --分数
)
GO

INSERT #Student 
 SELECT 1,'S01','一班',88
 UNION ALL SELECT  2,'S02','一班',66
 UNION ALL SELECT  3,'S03','一班',75
 UNION ALL SELECT  4,'S05','二班',30
 UNION ALL SELECT  5,'S06','二班',70
 UNION ALL SELECT  6,'S07','二班',80
 UNION ALL SELECT  7,'S08','二班',70
 UNION ALL SELECT  8,'S09','三班',90
 UNION ALL SELECT  9,'S010','三班',70
 UNION ALL SELECT  10,'S011','三班',80

GO

SELECT * FROM #Student

--分数总排名,不考虑并列情况
SELECT * ,ROW_NUMBER() OVER(ORDER BY Score DESC) AS 总排名,COUNT(*) OVER() AS 总人数 FROM #Student

--分数总排名,分数相同的做为并列排名,排名连续
SELECT *,DENSE_RANK() OVER (ORDER BY Score DESC) AS 总排名 FROM #Student

--分数总排名,分数相同的做为并列排名,排名不连续,如两个并列第二名,则下一个第四名(注意不是第三名)
SELECT *,RANK() OVER(ORDER BY Score DESC) AS 总排名 FROM #Student


--各班级分数排名,PARTITION BY对班级进行分组,然后再进行排名
SELECT * ,DENSE_RANK()OVER(PARTITION BY Class ORDER BY Score DESC) AS 各班级排名 FROM #Student

--使用OVER开窗函数与聚合配合,行集得到全部班级的总人数
SELECT *,COUNT(id) OVER()AS 总人数 FROM #Student


--使用OVER开窗函数与聚合配合,行集得到每个班级的各自总人数
SELECT *,COUNT(id) OVER(PARTITION BY Class)AS 总人数 FROM #Student