博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
查询每门学科成绩在前2位的记录,并按学科,成绩排序
阅读量:4567 次
发布时间:2019-06-08

本文共 931 字,大约阅读时间需要 3 分钟。

现在有学生成绩表,结构如下

Create Table StuAchievement (      StuId varchar(8),      CourseId varchar(10),      Achievement int)

数据就自己动动手录入吧

SELECT * FROM StuAchievement AWHERE EXISTS(        SELECT TOP 1 * FROM StuAchievement b         WHERE a.CourseId=b.CourseId AND b.Achievement >a.Achievement         HAVING COUNT(0)<=1)ORDER BY a.CourseId,a.Achievement DESC

或者

SELECT * FROM StuAchievement AWHERE NOT EXISTS(        SELECT TOP 1 * FROM StuAchievement b         WHERE a.CourseId=b.CourseId AND b.Achievement >a.Achievement         HAVING COUNT(0)>=2)ORDER BY a.CourseId,a.Achievement DESC

或者

--运用CTEWITH temp AS (    SELECT StuId,CourseId,ROW_NUMBER() OVER (PARTITION BY CourseId ORDER BY CourseId,Achievement DESC) AS rowId    FROM StuAchievement)SELECT * FROM StuAchievement a,temp b WHERE a.StuId=b.StuId AND a.CourseId=b.CourseId AND b.rowId<=2ORDER BY a.CourseId,a.Achievement DESC

 

转载于:https://www.cnblogs.com/DonnyPeng/p/3813428.html

你可能感兴趣的文章
Android 自定义 ViewPager 打造千变万化的图片切换效果
查看>>
泛型集合的运用--DataSet转换为泛型集合
查看>>
IsBackground的理解
查看>>
Java中的Scoket编程
查看>>
WPF邮件群发工具开发 之 进度条(属性改变通知机制)的实现
查看>>
ubuntu14.04 放开串口权限
查看>>
HttpClient封装工具类
查看>>
机器学习 回归算法
查看>>
SSM博客登录注册
查看>>
在Linux系统上部署发布java web系统(Ubuntu16.04)
查看>>
shell 学习之脚本编写1
查看>>
winForm 程序开发界面参数传递
查看>>
查询计算机启动了多长时间的工具
查看>>
【转】Spring MySQL 事务隔离级别,传播机制,savepoint
查看>>
IOS 开发中的KVC 和KVO
查看>>
05-Python基础之函数基础
查看>>
水晶苍蝇拍:价值投资的“基础,重点和核心” (2010-06-23 18:30:07)
查看>>
HTML超链接的使用
查看>>
h5微信支付在微信内页使用微信公众号支付
查看>>
分区函数Partition By的与row_number()的用法以及与排序rank()的用法详解(获取分组(分区)中前几条记录)(转)...
查看>>