Oracle 伪列

ROWNUM

ROWNUM:表示行号,实际上此是一个列,但是这个列是一个伪列,此列可以在每张表中出现。

范例:在查询雇员表上,加入 ROWNUM

SELECT ROWNUM,empno,ename,job,sal,hiredate FROM emp ;

从运行上看,ROWNUM 本身采用自动编号的形式出现。

假设只想显示前 5 条记录。条件中:ROWNUM<=5

SELECT ROWNUM,empno,ename,job,sal,hiredate
FROM emp WHERE ROWNUM<=5;

如果现在要想进行中间的截取操作,则只能采用子查询,例如现在假设每页显示 5 条,第 2 页应该显示 6~10 条,那么对于数据库操作来讲,它在查询的时候应该首先查询出 1~10 条,之后再在查询的结果中取出后 5 条。

SELECT *
FROM (SELECT ROWNUM rn,empno,ename,job,sal,hiredate
    FROM emp WHERE ROWNUM<=10) temp
WHERE temp.rn>5;

ROWID

ROWID:数据库中行的全局唯一地址,ROWID使用base64编码行的物理地址,编码字符包含 A-Z, a-z, 0-9, +, 和 /

rowid由四部分组成:OOOOOOOFFFBBBBBBRRR:

OOOOOO:数据对象编号(6位显示)FFF:相关数据文件编号(3位显示)BBBBBB:数据块编号(6位显示)RRR:数据块中行编号(3位显示)

 ROWID可用于删除数据表中重复数据

select rowid, emp.* from emp;

添加重复数据

insert into emp select * from emp where empno=7369;

新添加的数据其ROWID比之前的数据ROWID大,所以可以使用MIN函数选出非重复数据的ROWID

select min(rowid) from emp group by empno, ename,job,mgr,hiredate,sal,comm,deptno

删除重复数据

delete from emp where rowid not in (
  select min(rowid) from emp group by empno, ename,job,mgr,hiredate,sal,comm,deptno
);

再查看全部数据,重复数据已删除

 


  •   ROWNUM主要用于服务器分页
  •   ROWID可用于删除重复数据
时间: 2024-07-31 04:29:26

Oracle 伪列的相关文章

Oracle伪列(ROWNUM)的使用

先看一个题:查询emp表的信息,显示前5行数据,这时候我们就需要使用伪列(rownum)的概念. rownum在数据表并不是一个真实的列,其实每一行应该都有一个行号,这个伪列就是用来记录这个行号的,这个列可以进行一些操作,比如取等于和小于操作,不能取大于操作. *****查询emp表的信息,显示前5行数据***** SELECT * FROM emp WHERE rownum <= 5 ; 如果我们要查询第5-10行数据,这时候该怎么办?就需要使用到子查询. SELECT * FROM ( SE

Oracle Schema Objects——伪列ROWID Pseudocolumn(ROWNUM、ROWID)

Oracle Schema Objects Oracle Schema Objects——Tables——Oracle Data Types Oracle伪列 在Oracle数据库之中为了实现完整的关系数据库的功能,专门为用户提供了许多的伪列. “NEXTVAL”和“CURRVAL”就是两个默认提供的操作伪列Oracle Schema Objects——Sequences(伪列:nextval,currval) SYSDATE与SYSTIMESTAMP也属于伪列SQL Fundamentals

伪表和伪列

oracle的伪列以及伪表 oracle系统为了实现完整的关系数据库功能,系统专门提供了一组成为伪列(Pseudocolumn)的数据库列,这些列不是在建立对象时由我们完成的,而是在我们建立时由Oracle完成的.Oracle目前有以下伪列: 一.伪列: CURRVAL AND NEXTVAL 使用序列号的保留字 LEVEL 查询数据所对应的层级 ROWID 记录的唯一标识 ROWNUM 限制查询结果集的数量二.伪表 DUAL 表 该表主要目的是为了保证在使用SELECT语句中的语句的完整性而提

Oracle分页查询=======之伪列的使用

========伪列========== 在Oracle数据库中,伪列不存在表中,但是可以从表中查询到 例如:SELECT ROWID 伪列,tname 教师姓名 FROM teacher; =========列号rownum========== 查询rownum返回表中数据的行号; 例如:SELECT ROWNUM 列号,tname 教师,sal 薪资 FROM teacher; 其中rownum只能在条件中做=1或者小于 的操作 例如:SELECT tname 教师名,sal 薪资 FROM

oracle 之 伪列 rownum 和 rowid的用法与区别

rownum的用法 select  rownum,empno,ename,job from emp where rownum<6 可以得到小于6的值数据 select rownum,empno,ename,job from emp where rownum>6 and rownum<10 得不到数据  原因:oracle 中首先会产生编号为1的数据,也就是不满足条件,那么后面的同样会继续产生第二条数据同时也是编号为1,所以最后得不到数据 解决方案:可以将select rownum,emp

Oracle中的伪列

分页查询中,需要用到伪列rownum,代码如下: select * from (select rownum rn, name from cost where rownum <= 6) where rn >3; 可是第一次用rownum,第二次用rn,位置不能变,否则出错,第一次的rownum是oracle中的一个虚拟列,rn是给这个rownum起的别名,也就是在子查询中的别名要在外查询中调用. 如果先按工资排序,再取出6到10号,可以写成: select * from (select rown

Oracle(零)--&gt; 伪列和分组聚合(Oracle 开篇,比较初级啦~)

   写在开篇~    不知不觉已然到了开学的时候,毕竟这个大三连暑假还不知道是什么就上岗了,看着周围同学秀的简直飞起 =.= 扯淡扯多了,再扯一句..大三的时候学的 Oracle ,但是现在一想竟然不觉得有何内容,而且触发器,存储过程老师也没有教过,自己也没有看过,实在...毕竟华为工程师说的那句话还是依稀在眼前..不管怎么样,先搞明白是何物,以后才在项目中知道该如何去使用.本流程基本按学习过程中 PPT 来走的,而再往前的东西概念太多,大家又不是很喜欢字,都爱看图嘛~视频就算了,太刺激了都受

Oracle数据更新、事务处理、数据伪列

一.数据的更新操作 DML操作语法之中,除了查询之外还有数据的库的更新操作,数据的更新操作主要指的是:增加.修改.删除数据,但是考虑到emp表以后还要继续使用,所以下面先将emp表复制一份,输入如下指令: CREATE TABLE myemp AS SELECT * FROM emp; 这种语法是Oracle中支持的操作,其他数据库不一样. 1.数据增加 如果现在要想实现数据的增加操作,则可以使用如下的语法完成: INSERT INTO 表名称 [(字段1,字段2,-)] VALUES(值1,值

oracle 事务 数据伪列

在用户进行数据更新操作(DML)事务一定会起作用. 事务的出现会保证数据的完整性.一致性.在整个事务的处理过程之中主要使用两个操作命令: · 事务的提交(COMMIT):是真正的向数据库之中发出更新指令:· 事务的回滚(ROLLBACK):回滚到最初的状态. 一但用户发出了提交事务(commit)指令,那么所有的数据将被真实性的执行了更新操作.此时将无法使用 rollback进行回滚. 在 Oracle 之中,每一个连接到数据库上的用户,都使用一个 session 的概念表示.每一个 Sessi