sql%rowcount用于记录修改的条数,就如你在sqlplus下执行delete from以后提示已删除xx行同样, 这个参数必需要在一个修改语句和commit之间放置,不然你就得不到正确的修改行数。sql
例如:
SQL> declare n number;
2 begin
3 insert into test_a select level lv from dual connect by level<500;
4 n:=sql%rowcount;
5 commit;
6 dbms_output.put_line(n);
7 end;
8 /
499
PL/SQL procedure successfully completed.
SQL> declare n number;
2 begin
3 insert into test_a select level lv from dual connect by level<500;
4 commit;
5 n:=sql%rowcount;
6 dbms_output.put_line(n);
7 end;
8 /
0
PL/SQL procedure successfully completed.
×××××××××××××it
若是我连续执行了3个select语句
而后调用sql%rowcount,获得的结果是最后一个select的条数。 要统计全部的,能够使用三个变量接收sql%rowcount,而后相加便可,不过貌似直接select的写法没法使用sql%rowcount。test