小编典典

如何使用rownum

sql

我在oracle中有一个employee表,其中包含名称,薪水和其他详细信息。

我正在尝试拿第二高的薪水,但无法拿到。

这一个工作正常

with e_salary as (select distinct salary from employee)
select salary from e_salary
order by salary desc

并给出输出:

450000

61000

60000

50000

40000

30000

20000

6000

但是当我使用相同的查询来获取第二高的行而没有得到任何输出时

select salary
  from ( with e_salary as (select distinct salary from employee)
         select salary from e_salary order by salary desc)
 where rownum = 2

但是当我更换rownum=2rownum<2它给人的第一两项纪录输出。请有人解释为什么rownum=2不起作用


阅读 179

收藏
2021-05-05

共1个答案

小编典典

这将起作用:

从(从薪金中选择e_salary订单中的薪水,按薪水从十进制中选择rn)从(中选择薪水,rownum作为rn)选择薪水,其中rn = 2;

为什么不起作用:

在将ROWNUM分配给一行时,Oracle从1开始,并且仅在选择了一行时才递增该值;否则,Oracle仅从1开始递增该值。
也就是说,当WHERE子句中的所有条件都满足时。由于我们的条件要求ROWNUM大于2,所以不会选择任何行,并且ROWNUM永远不会增加到1以上。

希望你现在很清楚。

2021-05-05