`

oracle 伪列 rownum

阅读更多
SELECT * FROM 审批记录 WHERE rownum<=20;

该语句为取表【审批记录】中的前20行记录。

SELECT rn,集团编号 FROM (SELECT rownum AS rn, 审批记录.* FROM 审批记录 WHERE rownum<=30) 审批记录 WHERE rn>20;

该语句显示的是表【审批记录】中的第21-30行,一般用于对结果集进行分页显示。

select rn,集团编号 from (select m.*, rownum rn from (select * from 审批记录 order by 集团编号) m where rownum <= 30) where rn > 20;

该语句显示10条记录,但与上一条sql语句显示的结果不一样(去掉"order by 集团编号",查询结果将是一样的),也可以用于对结果集进行分页显示(推荐)。

update 号码分配_导入 set 号码=号码+rownum-1;


该语句实现每个号码加上 1,第一个记录除外。效果如下:

SQL> select 号码 from 号码分配_导入;


号码
--------------------
89229000
89229000
89229000
89229000
89229000
89229000
89229000
89229000

8 rows selected

SQL> update 号码分配_导入 set 号码=号码+rownum-1;


8 rows updated

SQL> select 号码 from 号码分配_导入;


号码
--------------------
89229000
89229001
89229002
89229003
89229004
89229005
89229006
89229007

8 rows selected

备注:字段【号码】数据类型可以是varchar,但必须是数字型的数据。

补充:(引自-http://xining.iteye.com/blog/365681)
1、oracle的伪列:
oracle系统为了实现完整的关系数据库功能,系统专门提供了一组称为伪列(Pseudocolumn)的数据库列,这些列不是在建立对象时由我们完成的,而是在我们建立时由Oracle完成的。Oracle目前有以下伪列:

  currval 和 nextval 使用序列号的保留字
  level 查询数据所对应的级
  rowid 记录的唯一标识
  rownum 限制查询结果集的数量

2、oracle的伪表

dual
该表主要目的是为了保证在使用SELECT语句中的语句的完整性而提供的。
分享到:
评论

相关推荐

    17.Oracle伪列1

    【Oracle伪列详解】 在Oracle数据库中,伪列是一种特殊的数据类型,它们表现得像普通列,但并不实际存储在表中。Oracle提供了两种主要的伪列:rowid和rownum,它们各自拥有独特的功能和用途。 一、rowid伪列 1. ...

    oracle数据库伪列简单介绍

    ### Oracle数据库伪列简析:rownum与rowid的区别 在Oracle数据库中,存在一种特殊的数据类型被称为“伪列”,这些伪列虽然看起来像是表中的列,但实际上它们并不存储任何数据,而是由数据库动态生成的。本文将重点...

    Oracle中使用伪列rownum实现分页查询

    Oracle提供了一种特殊类型的列,称为伪列(Pseudo-Column),其中一个最著名的例子就是`ROWNUM`。`ROWNUM`伪列在查询执行时自动为每一行分配一个唯一的整数,从1开始递增。在分页查询中,我们可以巧妙地利用`ROWNUM`...

    oracle的伪列与分页

    综上所述,Oracle伪列如ROWID和ROWNUM在实际应用中发挥着重要作用,不仅可以帮助优化查询性能,还能轻松实现复杂的分页功能。同时,通过Java JDBC编程,可以进一步提升应用程序与Oracle数据库的集成度和灵活性。

    oracle伪列以与伪表.doc

    以下是关于Oracle伪列和伪表的详细说明: 一、Oracle伪列 1. `CURRVAL` 和 `NEXTVAL`:这两个伪列与Oracle序列有关。`CURRVAL`返回序列的当前值,而`NEXTVAL`则递增序列并返回新的值。它们通常用于生成唯一的...

    对于 Oracle 的 rownum 问题

    =),并非说用&gt;,&gt;=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来,其实您只要理解好了这个 rownum 伪列的意义就不应该感到惊奇,同样是伪列,rownum 与 rowid ...

    oracle伪列以及伪表.doc

    一、Oracle伪列 1. CURRVAL 和 NEXTVAL:这两个伪列与序列号相关,CURRVAL返回序列的当前值,而NEXTVAL则递增序列并返回新值。 2. LEVEL:在递归查询或层次查询中,LEVEL伪列用来表示数据在树形结构中的深度或层级...

    oracle伪列以及伪表.docx

    Oracle数据库系统中,伪列和伪表是两个特殊的概念,它们为数据库操作提供了额外的功能和便利。本文将详细探讨这两个概念及其应用场景。 首先,我们来理解什么是伪列。伪列并非用户在创建表时定义的列,而是Oracle...

    ORACLE 中ROWNUM用法总结

    在Oracle数据库中,`ROWNUM`是一个非常有用的伪列,用于限制查询结果的行数,尤其是在处理大数据量或进行分页查询时。然而,`ROWNUM`的使用并不直观,尤其是当涉及到比较运算符(如`&gt;`, `&gt;=`, `=`等)时,容易引发...

    ROWNUM的使用技巧

    ROWNUM 是 Oracle 中的一种伪列,它可以根据返回记录生成一个序列化的数字。利用 ROWNUM,我们可以生产一些原先难以实现的结果输出,但是因为它是伪列的特殊性,在使用时需要注意一些事项,以免掉入“陷阱”。 特殊...

    oracle-rownum用法

    ROWNUM 是 Oracle 系统中一个伪列,用于对查询返回的行进行编号,从 1 开始,每行递增 1。ROWNUM 可以用于限制查询返回的总行数,但需要注意的是,ROWNUM 不能以任何表的名称作为前缀。 等于某值的查询条件 在使用...

    关于oracle的rownum

    Oracle ROWNUM 伪列详解 Oracle 的 ROWNUM 伪列是一个非常重要的概念,它对结果集加的一个伪列,即先查到结果集之后再加上去的一个列。了解 ROWNUM 的意义是非常重要的,否则可能会出现莫名其妙的结果。 ROWNUM ...

    oracle rownum 学习

    这是因为ROWNUM是一个总是从1开始的伪列,Oracle认为`ROWNUM&gt;n`(n&gt;1的自然数)这种条件不成立。可以使用子查询方法来解决,例如: ```sql SELECT * FROM ( SELECT ROWNUM NO, ID, NAME FROM STUDENT ) WHERE NO &gt; 2;...

    Oracle--ROWNUM.rar_oracle

    首先,`ROWNUM`是一个内置的伪列,它会在查询结果集产生时自动为每一行分配一个唯一的整数,从1开始递增。这个序列号并不存储在表中,而是在执行SQL查询时动态生成。因此,`ROWNUM`的值取决于查询的顺序,而不是表中...

    oracle rownum 的使用 和sqlserver有区别的!

    在数据库操作中,ROWNUM 是一个非常重要的伪列,主要用于返回查询结果的行序号。它在 Oracle 数据库中有着广泛的应用场景,尤其是在需要对查询结果进行分页显示、排序或者统计特定范围内的记录时尤为重要。本文将...

    解析oracle的rownum

    Oracle 中的 ROWNUM 是一个伪列,用于对查询返回的行进行编号,返回的第一行分配的是 1,第二行是 2,以此类推。这个伪列可以用于限制查询返回的总行数。下面我们将通过实例来详细解析 ROWNUM 的使用方法和技巧。 ...

    oracle中利用关键字rownum查询前20名员工信息及rownum用法

    注意:对 rownum(伪列) 只能使用 &lt; 或 &lt;=, 而用 =, &gt;, &gt;= 都将不能返回任何数据  例:查询工资前20名的员工姓名,工资 ,工资由高到低 Select rownum,first_name,salary from (Select first_name, salary ...

    oracle的rownum用法

    Oracle的`ROWNUM`是一个伪列,它在查询结果集中自动添加,并从1开始为每一行赋予一个唯一的数字。在处理大数据集时,`ROWNUM`常用于限制返回的行数,实现分页或者筛选特定范围的记录。然而,正确理解和使用`ROWNUM`...

    Oracle rownum.docx

    ROWNUM是一个伪列,表示从查询结果中返回的每一行的序列号,从1开始递增。 首先,当使用ROWNUM等于某个特定值时,比如ROWNUM=1,这种情况下可以有效地获取到第一条记录。然而,尝试使用ROWNUM=2或其他大于1的数字则...

    伪列(pseudo column)ROWNUM介绍

    在Oracle数据库中,`ROWNUM`是一个非常有用的伪列(也被称为虚拟列),它为每一行分配了一个唯一的行号。该行号从1开始递增,但请注意,`ROWNUM`并不是表的一部分,也不会存储在表中;相反,它是在查询执行过程中...

Global site tag (gtag.js) - Google Analytics