查询数据库中第二大的记录的几种方法

Posted cangbaijun

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查询数据库中第二大的记录的几种方法相关的知识,希望对你有一定的参考价值。

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

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

首先我看到了以下方法

方法一:

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

 



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

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

 



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

方法二:

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

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

 


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

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

 


方法三:

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

 

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

 



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

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

































以上是关于查询数据库中第二大的记录的几种方法的主要内容,如果未能解决你的问题,请参考以下文章

SQL重复记录查询的几种方法

SQL重复记录查询的几种方法

求数组中第二大的值

SQL-重复记录查询的几种方法

SQl重复记录查询的几种方法

SQL重复记录查询的几种方法