sql查询每科成绩的最高分_SQL查询每科分数最高的

假设数据表 examinationiɡ 有以下数据:+----+------+---------+--------+

| id | name | subject | number |

+----+------+---------+--------+

| 1  | A    | 数学    | 100    |

| 2  | A    | 语文    | 90     |

| 3  | A    | 英语    | 70     |

| 4  | B    | 数学    | 60     |

| 5  | B    | 语文    | 70     |

| 6  | B    | 英语    | 80     |

+----+------+---------+--------+

现在的需求是:获取 数学 / 语文 / 英语 三个科目每个科目最高分的。 通俗点说就是获取每科第一名的。

可以使用 JOIN:SELECT e1.*

FROM `examinationiɡ` e1

JOIN(

SELECT `subject`, MAX(number) max_number

FROM `examinationiɡ`

GROUP BY `subject`

) e2 ON e1.`subject` = e2.`subject` AND e1.number = e2.max_number

返回的结果:+----+------+---------+--------+

| id | name | subject | number |

+----+------+---------+--------+

| 1  | A    | 数学    | 100    |

| 2  | A    | 语文    | 90     |

| 6  | B    | 英语    | 80     |

+----+------+---------+--------+

如果只需要某个科目可以这样:SELECT e1.*

FROM `examinationiɡ` e1

JOIN(

SELECT `subject`, MAX(number) max_number

FROM `examinationiɡ`

GROUP BY `subject`

) e2 ON e1.`subject` = '数学' AND e1.number = e2.max_number

返回的结果:+----+------+---------+--------+

| id | name | subject | number |

+----+------+---------+--------+

| 1  | A    | 数学    | 100    |

+----+------+---------+--------+

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值