ORACLE中的SQL%ROWCOUNT

本文深入探讨了SQL%ROWCOUNT在Oracle数据库中的作用,通过具体实例展示了如何利用此特性来准确记录修改操作的行数,强调了在执行修改语句后必须进行commit操作的重要性,以确保获取到正确的修改行数。文章还指出,连续执行多个select语句后调用SQL%ROWCOUNT可能得到的是最后一个SELECT的条数,因此提出了使用多个变量相加的方法来统计所有查询的总行数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

分类:

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

例如:

  1. 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.     /  
  1. PL/SQL procedure successfully completed.  
  2. SQL> declare n number;  
  3.     begin  
  4.     insert into test_a select level lv from dual connect by level<500;  
  5.     commit;  
  6.     n:=sql%rowcount;  
  7.     dbms_output.put_line(n);  
  8.     end;  
  9.     /  
  1. PL/SQL procedure successfully completed.  
  2. ******************  

如果我连续执行了3个select语句然后调用SQL%ROWCOUNT,得到的结果是最后一个SELECT的条数。  要统计所有的,可以使用三个变量接收SQL%ROWCOUNT,然后相加即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值