sql分组之后取最小值行的记录

本文详细介绍了如何使用SQL对学生成绩数据进行分组,以找出每个班级每个科目的最高分。通过具体实例,展示了如何构建SQL查询语句,实现数据的有效分析。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

sql分组之后取最小值行的记录
比如:一个表中存储了所有班级所有学生的英语、数学、语文的成绩。
表结构如下:

CREATE TABLE `student_grades` (
`id` bigint(20) unsigned NOT NULL DEFAULT '0', -- 主键
`ver` mediumint(8) unsigned NOT NULL DEFAULT '0', -- 乐观锁版本号
`classid` bigint(20) unsigned NOT NULL DEFAULT '0', -- 班级ID
`studentid` varchar(50) NOT NULL DEFAULT '', -- 学生ID
`subjectid` tinyint(2) unsigned NOT NULL DEFAULT '0', -- 学科ID
`grade` tinyint(3) unsigned NOT NULL DEFAULT '0', -- 分数
`ctime` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00', -- 创建时间
`utime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, -- 更新时间
PRIMARY KEY (`id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

如何求出每个班每个科目的最高分?
sql如下:

select max(grade), classid, subjectid from student_grade group by classid, subjectid ;

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值