关于Oracle中伪列rownum的使用简介

本文介绍了 Oracle 数据库中 ROWNUM 的工作原理及其常见用法。通过具体示例展示了如何正确使用 ROWNUM 进行数据筛选和排序,特别强调了 ROWNUM 在 ORDER BY 操作前生成的特点。
摘要由CSDN通过智能技术生成

       由于之前没有注意过rownum的介绍,对其认识仅仅是知道可以通过它来进行一些简单的数据筛选、分页等功能,最近在对其进行条件查询筛选时,发现得到的并不是想要的数据,查看了一些其他的文档,现在想简单的介绍一下使用该伪列时,应当注意的事项。

示例如下: 

从表中查询有以下数据

> select  t.* from t_example_info t;

当时想选择出开始时间(start_time)最大的一条数据记录,于是执行了如下的SQL,结果发现所找的并不是希望的数据;

> select  t.* from t_example_info t  where rownum = 1 order by t.start_time desc;

当时很是不解,于是查看了一些文档介绍:Oracle中的rownum的是在取数据的时候产生的序号,它是系统按照记录被取出时给记录编的号,而不是把数据取出并排序,然后再进行对记录集合编号,也就是rownum的产生是在order by的操作之前就已经确定了的,因此导致order by 语句失效,所以无法得到想要的结果。当知道了rownum产生的原理之后,上面的问题就自然而然的解决了。

select  s.*  from (select t.* from t_example_info t order by t.start_time desc) s where rownum = 1;

同时还应注意的有:

1)rownum不能使用任何表的名称作为前缀,它是Oracle系统自带的;

2)rownum的值是从1开始的,若直接对其做rownum>=n(n>1)的条件筛选时,认为rownum>=n返回的结果是false,从而查询并不会有结果返回;

总之,只要记着rownum的值是在查询出的结果后产生的,并且起始值是1开始的就OK了!!!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值