查询前两名学生的成绩的信息(转载)

在SQL Server 数据库中,有一个表StudentAchievement(学生成绩),

它有三个字段:StudentID(varchar(8),学生编号),CourseID(varchar(10),课程编号),Achievement(int ,成绩),

写一条SQL语句,筛选出每门课程的前两名的学生编号,课程编号,成绩并排序。

--方法一

--将每科前两名学生的ID取出

/*

这是个自连接问题,可以这样想,就是把studentachievement表看成两个表,A和B,

A取的是B表中筛选出来的ID,而B表中筛选出来的ID则要靠A中的courseID来筛选,

即A表里选出来的是和B表courseID相同的,但在B表中占前两项的值。

 1 */
 2 
 3 SELECT *
 4 
 5 FROM STUDENTACHIEVEMENT A
 6 
 7 WHERE STUDENTID IN (SELECT TOP 2 STUDENTID
 8 
 9                        FROM STUDENTACHIEVEMENT B
10 
11                       WHERE B.COURSEID = A.COURSEID
12 
13                       ORDER BY B.ACHIEVEMENT DESC)
14 
15 ORDER BY A.COURSEID, A.ACHIEVEMENT DESC

 

--方法二

--以科目,按成绩给记录编号,然后取出编号<=2的,就是每科前两名

 1 SELECT *
 2 
 3 FROM STUDENTACHIEVEMENT A
 4 
 5 WHERE (SELECT COUNT(*)
 6 
 7           FROM STUDENTACHIEVEMENT B
 8 
 9          WHERE B.COURSEID = A.COURSEID
10 
11            AND B.ACHIEVEMENT >= A.ACHIEVEMENT) <= 2
12 
13 ORDER BY A.COURSEID, A.ACHIEVEMENT DESC

 

posted @ 2016-11-07 13:42  雨花宝宝  阅读(514)  评论(0编辑  收藏  举报