1.rownum是伪列,是在获取查询结果集后再加上去的 (获取一条记录加一个rownum)。对符合条件的结果添加一个从1开始的序列号。
eg:
select rownum,phone_no from ur_user_info where rownum < 6;
attention:
rownum是动态的,必有查询结果,然后再给查询的结果集添加上这个列。 例如:第一条记录的rownum是1 ,第二条是2,以此类推。
select rownum, phone_no from ur_user_info where rownum > 5 and rownum < 10; ---查询结果为空集
当产生结果集时,oracle会产生一条rownum为1的记录,显然不符合条件;那么就会产生第二条记录,同样rownum=1,也不符合记录; 一直下去,导致最后上述sql产生的结果集时空集。
如果需要查询到结果,需要使用子查询:
-----错误写法:
select rownum, phone_no
from (select rownum rn , phone_no from ur_user_info ) a
where a.rownum > 5 and a.rownum < 10;
-----正确写法:
select rownum,*
from (select rownum rn, a.* from ur_user_info a where rownum < 10) a
where a.rn > 5;
--注意: 1.rownum只能用< 或者
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?