Rownum 和 RowidOracle数据库所特有的,通过他们可以查询到指定行数范围内的数据记录。

 

以下通过例子讲解:

-- 为了方便,首先,查找dept表中的所有。

select deptno,dname,loc from scott.dept;

-- Rownum

-- 可以查询 rownum(行数) 为 1 的数据

select rownum,deptno,dname,loc

from scott.dept

where rownum = 1;

-- 如果直接查询 rownum 为 2 的数据,返回是 null

-- 因为 rownum 是临时产生的一个“伪列”

-- 是先获取到全部的数据之后,才决定如何分配 rownum

-- 需要先搞定 1,才能知道下一个是 2,即需要从1开始查起。

 

-- 查询最前面两条的记录

select rownum,deptno,dname,loc

from scott.dept

where rownum < 3;

-- 会从1开始查起,查到后接着查询2...直到不符合条件。

 

-- 下面查询结果为 null,因为1没有查,接下来的无从查起。

select rownum,deptno,dname,loc

from scott.dept

where rownum > 3;

-- 1开始查起,直到全部。

select rownum,deptno,dname,loc

from scott.dept

where rownum > 0;

-- Rowid是一串随机生成的字符串,也是 Oracle 提供的一个数列。

-- Rownum 和 Romid 区别

-- 一般情况下,每一行数据对应一个 rowid,这个值是固定而且唯一的。

-- 在这行数据存入数据库的时候,就确定的了,自动生成的。

-- 相当于我们 Java 对象在堆内存中对应有一个固定的地址值。

-- 可以使用 rowid 来查询记录,通过它可以提高我们的查询速度

-- 因为会有一张表单独保存 rowid,如果在查询的时候,

-- 需要扫描的列越少,速度就会越快,也是 oracle 查询最快的方式之一

-- rowid 在你的表发生移动时候,也会跟着一起发生改变。

-- 最大的一个作用:因为是唯一的,可以用来避免重复数据。

select rowid, deptno, dname, loc

from scott.dept

where rowid = 'AAAR3qAAEAAAACHAAC';

oracle数据库之rownum和rowid用法的更多相关文章

  1. Oracle数据库中序列(SEQUENCE)的用法详解

    Oracle数据库中序列(SEQUENCE)的用法详解   在Oracle数据库中,序列的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值.本文我们主要介绍了 ...

  2. Oracle中的rownum 和rowid的用法和区别

    Oracle中的rownum 和rowid的用法和区别   1.rownum是伪列,是在获取查询结果集后再加上去的 (获取一条记录加一个rownum).对符合条件的结果添加一个从1开始的序列号. eg ...

  3. Oracle数据库之rownum

    1. 介绍 当我们在做查询时,经常会遇到如查询限定行数或分页查询的需求,MySQL中可以使用LIMIT子句完成,在MSSQL中可以使用TOP子句完成,那么在Oracle中,我们如何实现呢? Oracl ...

  4. oracle数据库触发器(trigger)用法总结

    from:http://blog.csdn.net/zhanzhib/article/details/48729417 触发器的意思就是当我们对数据库对象(一般是表或视图)进行insert.updat ...

  5. 关于Oracle数据库的rownum应用

    它是Oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,以此类推,这个伪字段可以用于限制查询返回的总行数,而且rownum不能以任何表的名称作为前缀. 如以下语句将无法 ...

  6. java 查询oracle数据库所有表DatabaseMetaData的用法

    DatabaseMetaData的用法(转) 一 . 得到这个对象的实例 Connection con ; con = DriverManager.getConnection(url,userName ...

  7. Oracle中的rownum和rowid

    http://blog.csdn.net/mitedu/article/details/3584399  rownum http://blog.csdn.net/mitedu/article/deta ...

  8. oracle数据库查询语句case的用法

    实现功能: 1.先查询status=2的记录,如果查询到记录则返回第一条记录的Product_Name:2.如果查询不到status=2的记录,则判断status=1的记录是否存在,不存在则返回“请耐 ...

  9. oracle数据库中sql%notfound的用法

    SQL%NOTFOUND 是一个布尔值.与最近的sql语句(update,insert,delete,select)发生交互,当最近的一条sql语句没有涉及任何行的时候,则返回true.否则返回fal ...

随机推荐

  1. 解密虚拟 DOM——snabbdom 核心源码解读

    本文源码地址:https://github.com/zhongdeming428/snabbdom 对很多人而言,虚拟 DOM 都是一个很高大上而且远不可及的专有名词,以前我也这么认为,后来在学习 V ...

  2. mysql中FIND_IN_SET函数的使用

    有种需求,A和B是父子关系,B和C是父子关系,C与D亦是父子关系,以此类推,无限级 现在需要查询到某一级(包括本级)下面所有的,就需要用到FIND_IN_SET函数 select * from tab ...

  3. [BJWC2011]最小三角形

    嘟嘟嘟 这一看就是平面分治的题,所以就想办法往这上面去靠. 关键就是到\(mid\)点的限制距离是什么.就是对于当前区间,所有小于这个距离的点都选出来,参与更新最优解. 假设从左右区间中得到的最优解是 ...

  4. class , field , method

    Class类 由于Class类没有公共构造方法,所以创建Class的对象的方法有以下几种: 1.通过Class.forName静态方法返回Class类的一个实例 2.通过类名.class来获取一个Cl ...

  5. javascript:apply方法 以及和call的区别 (转载)

    javascript:apply方法   1.        apply和call的区别在哪里 2.        什么情况下用apply,什么情况下用call 3.        apply的其他巧 ...

  6. Metronic前端模板

    Metronic前端模板是我现在公司正在使用的,觉得还是蛮强大,最重要的是只要有Bootstrap的使用经验或者HTML.CSS.JS基础足够好,完全可以玩转它. 当然了,就算不好也没有关系,对于使用 ...

  7. springboot整合mybatis将sql打印到日志

    在前台请求数据的时候,sql语句一直都是打印到控制台的,有一个想法就是想让它打印到日志里,该如何做呢? 见下面的mybatis配置文件: <?xml version="1.0" ...

  8. Parameter server(参数服务器)

    特殊点在于参数服务器是节点存储参数的地方. 用于配置参数, 全局共享参数. 参数服务器使用互联网传输, 在节点管理器中运行, 实现整个通信过程. 1.命令行维护 load&&dump文 ...

  9. 用java数组模拟购物商城功能与实现

    实体类1(商品): package mall.model; public class goods { private int shoppingID; // 商品编号 private String sh ...

  10. 一、Django的简介

    2019-04-09 22:58:22 大家好,我是一名普普通通的运维工程师,不甘平庸,想在工作之余多学习一些编程技能,不仅提升自我,还能应用于公司的运维自动化工作(代码的自动发布等).希望今后在这记 ...