oracle returning

-- Created on 2014/7/6 by ADMINISTRATOR
declare
 row_id urowid;
 info varchar2(40);
begin
  update dept set deptno=70 where deptno=80
  returning rowid,deptno||':'||dname||':'||loc
  into row_id,info;
  dbms_output.put_line('行号:'||row_id);
  dbms_output.put_line('内容:'||info);
  commit;
end;

其中:RETURNING子句用于检索被修改行信息:当UPDATE语句修改单行数据时,RETURNING子句可以检索被修改行的ROWIDREF值,以及行中被修改列的列表达式,并可将他们存储到PL/SQL变量或复合变量中;当UPDATE语句修改多行数据时,RETURNING子句可以将被修改行的ROWIDREF值,以及列表达式值返回到复合变量数组中。在UPDATE中使用RETURNING子句的限制与INSERT语句中对RETURNING子句的限制相同。

rownum是对结果集加的一个伪列,即先查到结果集之后再加上去的一个列 (强调:先要有结果集)。简单的说 rownum 是对符合条件结果的序列号。它总是从1开始排起的。所以你选出的结果不可能没有1,而有其他大于1的值

ROWID是数据的详细地址,通过rowid,oracle可以快速的定位某行具体的数据的位置。

ROWID可以分为物理rowid和逻辑rowid两种。普通的表中的rowid是物理rowid,索引组织表(IOT)的rowid是逻辑rowid。

当表中有大量重复数据时,可以使用ROWID快速删除重复的记录。

ref  就是声明变量  游标作为变量处理的意思

你可能感兴趣的:(oracle,用法,returning)