oracle中的sql%rowcount(R2)

thamsyangsw發表於2014-03-11

轉載地址:http://blog.sina.com.cn/s/blog_713978a50100xi6z.html
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。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26613085/viewspace-1107644/,如需轉載,請註明出處,否則將追究法律責任。

相關文章