mysql查询第二高分数

对于mysql查询第N高数据问题,都有着类似的解法

题目

表stu结构如下,现在要查询第二高的成绩,如果查不到则显示null

+-------------+------+
| Column Name | Type |
+-------------+------+
| id          | int  |
| score       | int  |
+-------------+------+

示例数据和输出结果

输入:
+----+-------+
| id | score |
+----+-------+
| 1  | 100   |
| 2  | 200   |
| 3  | 300   |
+----+-------+
输出:
+-----------+
| scorerank |
+-----------+
| 200       |
+-----------+

输入:
+----+-------+
| id | score |
+----+-------+
| 1  | 100   |
+----+-------+
输出:
+-----------+
| scorerank |
+-----------+
| null      |
+-----------+

查询语句

SELECT IFNULL(
(SELECT DISTINCT salary FROM Employee ORDER BY salary DESC LIMIT 1,1)
,NULL) 
AS SecondHighestSalary

 如果有类似的查询语句,可以更改以下关键字,举一反三

distinct:去重(例:只有两个数据,都是100分,则不存在第二大,这种情况要去重)

order by:排序

desc:倒序(默认从小到大,如果要从大到小就需要desc)

limit(s,n):显示 [s,s+n) 的数据

ifnull(xxx,null):如果xxx结果为空则显示null

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值