关于在Mysql数据库中查询某表中第二大的数据的记录的方法及实现的sql语句

在学习过程中,遇到一个问题,查询最大的数据时十分容易,使用MAX函数语句即可,但是如何查询第二大的记录呢, 抱着这个问题我开始查找资料

首先建表语句,我建立了一个employee的表,属性有id,name和age,其中id为int 自增 主键,name为char(5),age为int型,创建及插入数据语句略去

首先我看到了以下方法

方法一:

select top 1 height from users where height not in (select MAX(height) from users) order by height desc;

该方法使用了Top函数,但当我去试验该方法后发现Mysql没有Top函数,只有Limit函数,但是也差不多,于是改进后的sql语句如下

select  height from users where height not in (select MAX(height) from users) order by height desc limit 1;

 该方法是首先查询出该表中最大的记录,然后排除该记录后再查询剩下数据中最大的记录。

方法二:

和上一方法类似,查询出最大的记录,然后查询剩下记录中比该记录小的最大数据记录,语句如下

SELECT MAX(age) AS age from empolyee
where age<(SELECT MAX(age)from empolyee)

经过试验后成功执行,但是查询出的记录只有age一项,改进后改为

SELECT * from empolyee
where age<(SELECT MAX(age)from empolyee) LIMIT 1

方法三:

使用rank函数,经过查询后得知mysql并没有rank函数,但是可以自己定义,经过查询rank函数定义的语句后,写出如下语句

SELECT r.id,age,rank from(
SELECT tmp.id,tmp.age,IF(tmp.id=@tmid,@rank:=1,@rank:=@rank+1) as rank,@tmid:=tmp.id
FROM (SELECT id,age from empolyee GROUP BY id,age ORDER BY id ASC,age DESC)tmp,
(select @rank:=0,@tmid:=null)tmp1
)r
WHERE age is not null and rank=2;

经过测试,能够成功查询出正确的记录 

经过学习,对Sql语句有了进一步的了解,还有一点感想就是oracle和sql sever有rank函数好方便啊,不像mysql只能自己定义

 

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值