由于之前没有注意过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了!!!