学生各门课程成绩统计SQL语句大全

这篇博客详细介绍了如何使用SQL语句进行学生成绩统计,包括计算个人总成绩排名、单科最高成绩、平均成绩,以及列出各科成绩最优学生等复杂查询。同时,还展示了数学成绩的排名情况和不及格、良、优等级分布。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

学生成绩表(stuscore): 

姓名:name 课程:subject 分数:score 学号:stuid
张三 数学 89 1
张三 语文 80 1
张三 英语 70 1
李四 数学 90 2
李四 语文 70 2
李四 英语 80 2



创建表 

SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOSET ANSI_PADDING ONGOCREATE TABLE [dbo].[stuscore](    [name] [varchar](50) COLLATE Chinese_PRC_CI_AS NULL,    [subject] [varchar](50) COLLATE Chinese_PRC_CI_AS NULL,    [score] [int] NULL,    [stuid] [int] NULL) ON [PRIMARY] GOSET ANSI_PADDING OFF



问题: 

1.计算每个人的总成绩并排名(要求显示字段:姓名,总成绩) 
2.计算每个人的总成绩并排名(要求显示字段: 学号,姓名,总成绩) 
3.计算每个人单科的最高成绩(要求显示字段: 学号,姓名,课程,最高成绩) 
4.计算每个人的平均成绩(要求显示字段: 学号,姓名,平均成绩) 
5.列出各门课程成绩最好的学生(要求显示字段: 学号,姓名,科目,成绩) 
6.列出各门课程成绩最好的两位学生(要求显示字段: 学号,姓名,科目,成绩) 
7.统计如下: 

学号 姓名 语文 数学 英语 总分 平均分
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值