在学习过程中,遇到一个问题,查询最大的数据时十分容易,使用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只能自己定义
原文地址:https://www.cnblogs.com/cangbaijun/p/9951558.html
时间: 2024-10-08 16:41:07