Oracle中的SQL%ROWCOUNT
sql%rowcount用于记录修改的条数,就如你在sqlplus下执行delete from之后提示已删除xx行一样,这个参数必须要在一个修改语句和commit之间放置,否则你就得不到正确的修改行数。
例如:
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.
×××××××××××××
如果我连续执行了3个select语句
然后调用sql%rowcount,得到的结果是最后一个select的条数。
要统计所有的,可以使用三个变量接收sql%rowcount,然后相加即可,不过貌似直接select的写法无法使用sql%rowcount。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。