MS SQL Server partition by 函数实战三 成绩排名

2024-09-02 23:52

本文主要是介绍MS SQL Server partition by 函数实战三 成绩排名,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

目录

需求

范例运行环境

视图样本设计

功能实现

基础数据展示

SQL语句

继续排序

小结


需求

假设有若干已更新考试成绩的考生,考试成绩包括总成绩、分项成绩1、分项成绩2,其它信息包括应聘岗位名称、姓名等信息。现希望根据总成绩计算排名,成绩越高排名越靠前,相同成绩排名并列,另外有并列则按总数递增,如两个第1后是第3。本文将继续介绍利用 partition by  来实现这一需求,主要实现如下功能:

(1)编写视图获取基础数据,包括人员基本信息和考试成绩数据等

(2)通过 partition by 计算排名,得到新的视图

(3)根据其它要求计算新的排名

范例运行环境

操作系统: Windows Server 2019 DataCenter

数据库:Microsoft SQL Server 2016

.netFramework 4.7.2

视图样本设计

视图成绩表 [v_cj] 设计如下:

序号字段名类型说明备注
1zwmcnvarchar职位名称应聘的岗位名称,以此进行分区排序
2xmnvarchar姓名
3kscj1float考试成绩1计算总成绩的一个分项
4kscj2float考试成绩2计算总成绩的一个分项
5kszcjfloat考试总成绩计算排名的依据

功能实现

基础数据展示

选择数据视图 v_cj,在查询分析器示例如下图:

如图这是随时显示的基础数据(未排序)。

SQL语句

排序的SQL语句,代码如下:

select  zwmc,xm,kscj1,kscj2,kszcj
,rank() over (partition by  zwmc order by kszcj desc) as ranktipfrom V_cj

运行查询分析器,显示结果如下:

如图框定部分,按最高成绩分值进行倒排序,分值越高排名越高。当成绩相同时则并列排序,下一排序号根据总排序号递增加1,如有两个第6名,则下个排名从第8名开始,以此类推。

关键语句:rank() over (partition by  zwmc order by kszcj desc),按 zwmc (职位名称)分区,以kszcj(考试总成绩) 降序排列,rank() 函数起到了排序功能。

继续排序

如果排序相同,则按分项成绩1继续排序,如果仍然一样则按分项成绩2继续排序,均为降序,SQL 语句如下:

select  zwmc,xm,kscj1,kscj2,kszcj,ranktipfrom V_cj order by zwmc,ranktip,kscj1 desc,kscj2 desc

代码继续将 ranktip 字段封装到 v_cj 视图中,然后按照设计的顺序进行排序,如下图运行分析结果查询:

小结

我们可以通过 row_number函数计算总排序(当排名相同时仍然以分项成绩1和分项成绩2降序计算排名,分值越高排名越靠前),可通过如下语句实现:

select  zwmc,xm,kscj1,kscj2,kszcj,ranktip,
row_number() over (partition by  zwmc order by kszcj desc,kscj1 desc,kscj2 desc) as ranktip2from V_cj

关键语句:row_number() over (partition by  zwmc order by kszcj desc,kscj1 desc,kscj2 desc),按 zwmc (职位名称)分区,以kszcj(考试总成绩) 降序排列,第二排序以kscj1(分项考试成绩1) 降序排列,,第三排序以kscj2(分项考试成绩2) 降序排列,row_number() 函数起到了总排序功能。

运行查询分析器,结果显示如下:

如图 ranktip2 字段显示了总排序,ranktip 字段显示了并列排序的情况,分项成绩参与了最终排序规则的实现。

更多 partition by 的聚合统计方法可参考我的文章 《MS SQL Server partition by 函数实战 统计与输出》

至此 partition by 的实例应用我们就介绍到这里,具体使用中我们还需要灵活掌握。感谢您的阅读,希望本文能够对您有所帮助。

这篇关于MS SQL Server partition by 函数实战三 成绩排名的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1131431

相关文章

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列