关于Oracle中伪列rownum的使用简介
来源:互联网 发布:山西大学大数据学院 编辑:程序博客网 时间:2024/05/22 05:18
由于之前没有注意过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了!!!
- 关于Oracle中伪列rownum的使用简介
- 关于oracle中rownum的使用探讨
- 关于oracle的rownum
- ORACLE的rownum使用
- oracle rownum的使用
- oracle的rownum使用
- oracle rownum的使用
- 关于ROWNUM的使用
- 关于ROWNUM的使用
- 关于Rownum的使用
- oracle数据库中伪列rownum\rowid的使用
- 关于oracle rownum的分析
- oracle关于rownum的【整理】
- Oracle中rownum的使用
- Oracle中rownum的使用
- Oracle中rownum的使用
- Oracle中ROWNUM的使用
- Oracle中rownum的使用
- 深拷贝和浅拷贝
- C++STL源码学习(之slist篇)
- 一个歌手的情书
- 安装nginx
- Cocos2d-x的生成Json文件的方法(续)
- 关于Oracle中伪列rownum的使用简介
- 关于NSTask使用的一些心得体会
- DBMS_METADATA 查看建表与建索引语句
- 是否放弃
- 工作周报014
- 成佩涛-浙江旅游职业管理学院后台漏洞
- zoj 3471(状态压缩DP)
- PHP 中cookie 和session 的分析
- error at ::0 can't find referenced pointcut..可能出现错误的原因