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

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 ;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值