当前位置: 首页 > 面试题库 >

如何使用rownum

杨景山
2023-03-14
问题内容

我在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不起作用


问题答案:

这将起作用:

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

为什么不起作用:

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

希望你现在很清楚。



 类似资料:
  • 如何使用

  • 将一段文档传入BeautifulSoup 的构造方法,就能得到一个文档的对象, 可以传入一段字符串或一个文件句柄. from bs4 import BeautifulSoup soup = BeautifulSoup(open("index.html")) soup = BeautifulSoup("<html>data</html>") 首先,文档被转换成Unicode,并且HTML的实例

  • 基础运用 Redis::set('user:profile:' . $id, "Swoft"); $userDesc = Redis::get('user:profile:' . $id); 你可以通过 Redis:: 调用任何 Redis 命令。Swoft 使用魔术方法将命令传递给 Redis 服务端,因此只需传递 Redis 命令所需的参数即可。示例: Redis::set('name',

  • 引入 WeUI.css文件 利用 vue init mpvue/mpvue-quickstart my-project 初始化一个 mpvue 项目,然后在 /src/main.js 中引入 weui.css 由于是在小程序中使用,于是就直接使用了 weiui-wxss 中的样式文件,官方提供的是 weui.wxss,因此手动转成了 weui.css,然后引入即可。 这里提供 weui.css 一

  • 将一段文档传入BeautifulSoup 的构造方法,就能得到一个文档的对象, 可以传入一段字符串或一个文件句柄. from bs4 import BeautifulSoup soup = BeautifulSoup(open("index.html")) soup = BeautifulSoup("<html>data</html>") 首先,文档被转换成Unicode,并且HTML的实例

  • 目录 简介 定义资源 主流框架的默认适配 抛出异常的方式定义资源 返回布尔值方式定义资源 注解方式定义资源 异步调用支持 规则的种类 流量控制规则 熔断降级规则 系统保护规则 访问控制规则 热点规则 查询修改规则 定制规则推送方式 其它 API 业务异常统计 Tracer 上下文工具类 ContextUtil 指标统计配置 规则生效的效果 判断限流降级异常 Dashboard 实时监控 简介 Se