oracle中的rownum详解

oracle中的rownum详解1.概述rownum是Oracle引入的虚列。在物理上这个虚列并不存在,只是在查询时才构造出来。伪列通常是自由分配的,用户无法执行修改等操作。2.特点关于rownum有以下主要特点:1)row

大家好,又见面了,我是你们的朋友全栈君。

1. 概述
rownum是Oracle引入的虚列。
在物理上这个虚列并不存在,只是在查询时才构造出来。伪列通常是自由分配的,用户无法执行修改等操作。

2. 特点
关于rownum有以下主要特点:

1)rownum不属于任何表。
2)rownum存在的前提,先有结果表。
3)rownum总是从1开始。
4)rownum一般只和<(<=)一起用。
5)使用rownum进行分页查询需要把rownum转化为实列,并针对rownum查询。
2. 机制原理
rownum的用法看似奇怪,其实如果明白其机制原理就会很简单。
首先我们来做个简单的实验:从dual表中取出所有的字段,并取出rownum。
如果我们采用如下的写法:t.rownum

<span role="heading" aria-level="2">oracle中的rownum详解

这样运行就会报01747错:

<span role="heading" aria-level="2">oracle中的rownum详解

因为实际上,dual表就不存在rownum这个字段,所以我们无法使用t.rownum的格式。
正确的写法,应该是:

<span role="heading" aria-level="2">oracle中的rownum详解

所以,rownum是一个虚列,不属于任何表。

那么这虚列是怎么来的。我们在做个简单的实验,便于理解:
如下,我们有一个简单的表:test_ljb,共有十条记录。
我们加上rownum。

<span role="heading" aria-level="2">oracle中的rownum详解

结果如下,很好理解,选出十条记录,rownum从1到10

<span role="heading" aria-level="2">oracle中的rownum详解

我们加上一个salary的筛选条件:

<span role="heading" aria-level="2">oracle中的rownum详解

结果如下:选出三条记录,rownum从1到3

<span role="heading" aria-level="2">oracle中的rownum详解

需要注意的是,第二个结果表的rownum对应的employee和第一张并不对应。
如:在第一张表rownum为1时,对应的时Arvin,而第二张对应的是Oracle。

原因如下:
因为rownum是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列。
简单的说,rownum是对符合条件结果的序列号。它总是从1开始排起的,所以选出的结果不可能跳过1,而有其他大于1的值。
或者说,rownum是一个动态的,根据新的结果集实时变化的。

比如,如下语句:

select t.*, rownum from test_ljb t where rownum >1; –大于2、3或者其他任何大于1的值,结果相同。

<span role="heading" aria-level="2">oracle中的rownum详解

我们发现没有符合条件的记录。

根据原理,rownum是对结果集的从1开始排。那么以上的语句的结果集是什么呢?

事实上,当执行完from test_ljb时,我们可以把他当作时一个结果表,rownum是从1-10。
然后,重点,当我们执行过滤条件,rownum>1 时,第一条记录不满足,剔除。这个时候,新的结果集产生了,原来的第二条记录就成了第一条,相应的rownum变为了1-9。
再次比较原来的第一条,现在的第二条记录,他的rownum也是1,也不满足,rownum是1-8。
以此类推,流水的记录,铁打的rownum从1开始。所以,直到rownum是1,还不满足。所以最后没有记录被筛选出来,也没了rownum。

所以,我们写出的这类语句:

<span role="heading" aria-level="2">oracle中的rownum详解

统统都是没结果的。

不过有意思的是,选出前十条,可以有好多写法:

<span role="heading" aria-level="2">oracle中的rownum详解

3. 用法
那有的同学就犯嘀咕了,我要做大于查询怎么搞啊,分页查询怎么搞啊,人家Mysql和Hive一个limit a, b 直接完事,你Oracle怎么搞。
其实方法还是有的,也是用rownum,不过要先把这货转化为实列。加个子查询就可以了。
老套路,简单实验走一波。

3.1 大于查询
还是test_ljb表,就选>5行。

<span role="heading" aria-level="2">oracle中的rownum详解

3.2.1 简单分页查询
<span role="heading" aria-level="2">oracle中的rownum详解

<span role="heading" aria-level="2">oracle中的rownum详解

3.3.2 排序分页查询
排序分页查询就麻烦了,首先要排序,然后再排序的基础上再筛选。
当然这个也是实际项目最常用的。
选出薪水最高的第4、5、6个。

 

<span role="heading" aria-level="2">oracle中的rownum详解

这里需要注意的是:rownum仅仅针对新的结果集动态标记,而排序并不会生成新的结果集,如果仅仅执行

<span role="heading" aria-level="2">oracle中的rownum详解

结果如下:

<span role="heading" aria-level="2">oracle中的rownum详解

来源:CSDN
原文:https://blog.csdn.net/qq_36743482/article/details/78919904
版权声明:本文为博主原创文章,转载请附上博文链接!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155285.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 红色故障码大全_最短路问题算法

    红色故障码大全_最短路问题算法原题链接战争中保持各个城市间的连通性非常重要。本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报。注意:若该国本来就不完全连通,是分裂的k个区域,而失去一个城市并不改变其他城市之间的连通性,则不要发出警报。输入格式:输入在第一行给出两个整数N(0 < N ≤ 500)和M(≤ 5000),分别为城市个数(于是默认城市从0到N-1编号)和连接两城市的通路条数。随后M行,每行给出一条通路所连接的两个城市的编号,其间以1个空格分隔。在城市信息之后给出被攻占的

    2022年8月8日
    4
  • 贝叶斯优化python包_贝叶斯优化

    贝叶斯优化python包_贝叶斯优化万壑松风知客来,摇扇抚琴待留声1.文起本篇文章记录通过Python调用第三方库,从而调用使用了贝叶斯优化原理的Hyperopt方法来进行超参数的优化选择。具体贝叶斯优化原理与相关介绍将在下一次文章中做较为详细的描述,可以参考这里。Hyperopt是Python的几个贝叶斯优化库中的一个。它使用TreeParzenEstimator(TPE),其它Python库还包括了S…

    2025年8月15日
    4
  • pycharm安装的基本步骤_pycharm32位怎么安装

    pycharm安装的基本步骤_pycharm32位怎么安装pycharm的安装步骤

    2022年8月27日
    8
  • C++中深入理解dynamic_cast

    C++中深入理解dynamic_cast转载:https://blog.csdn.net/gaojing303504/article/details/78860773dynamic_cast运算符的主要用途:将基类的指针或引用安全地转换成

    2022年7月4日
    22
  • rocketmq的原理_dns原理及其解析过程

    rocketmq的原理_dns原理及其解析过程1如何保证消息的可靠性传输生产者丢失数据:生产者设置同步提交消息,并且手动提交,将消息同步刷盘到从节点后在返回成功,broker:主从复制,同步刷盘消费端:消费重试,只有返回consume_success才算消费完成,保证消息的可靠性,最终还是消费16次还是失败的会进死信队列2.如何保证消息不被重复消费消费端消费消息的幂等1服务端代码根据messageId设置分布式锁,获取锁再做业务操作2更新数据库时校验业务的状态3或者设置唯一索引3.如何保证消息的顺序性…

    2025年6月27日
    2
  • nextSibling 和nextElementSibling的区别[通俗易懂]

    nextSibling 和nextElementSibling的区别[通俗易懂]使用nextSibling属性返回指定节点之后的下一个兄弟节点,(即:相同节点树层中的下一个节点)。nextSibling属性与nextElementSibling属性的差别: nextSibling属性返回元素节点之后的兄弟节点(包括文本节点、注释节点即回车、换行、空格、文本等等); nextElementSibling属性只返回元素节点之后的兄弟元素节点(不包括文本节点、注释节点);注意:空…

    2022年7月13日
    14

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号