oracle中的sql%rowcount

sql%rowcount用于记录修改的条数,就如你在sqlplus下执行delete from之后提示已删除xx行一样,这个参数必须要在一个修改语句和commit之间放置,否则你就得不到正确的修改行数。

例如:

declare n number;
begin
  insert into test_a select level lv from dual connect by level<500;
  n:=sql%rowcount;
  commit;
  dbms_output.put_line(n);
end;
/

 

declare n number;
begin
  insert into test_a select level lv from dual connect by level<500;
  commit;
  n:=sql%rowcount;
  dbms_output.put_line(n);
end;
/

 

如果连续执行了几个select语句
然后调用sql%rowcount,得到的结果是最后一个select的条数。 
要统计所有的,可以使用三个变量接收sql%rowcount,然后相加即可,不过貌似直接select的写法无法使用sql%rowcount。

posted @ 2014-10-02 23:47  wolfplan  阅读(5505)  评论(0编辑  收藏  举报