欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

oracle中sql%rowcount的作用詳解

 更新時間:2023年05月30日 16:04:56   作者:zhu2695  
這篇文章主要介紹了oracle中sql%rowcount的作用,sql%rowcount來判斷是否更新了記錄的狀態(tài),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

起因:新開發(fā)個存儲過程,需要當一個用戶調用存儲過程操作一行數(shù)據(jù)時,另外的用戶不允許調用過程操作該數(shù)據(jù)。

解決辦法:先將該記錄的狀態(tài)改為處理中,當別的用戶看到為處理中時則跳出過程。此時用到了sql%rowcount來判斷是否更新了記錄的狀態(tài)

update table t set t.status = 'processing' where t.id = P_ID and t.status <> 'processing' ;  
if sql%rowcount = 0 then  
  return;  
end if;  

由于沒有用過sql%rowcount,所以特意測試了一下,下面是對sql%rowcount功能的測試:

--先建個測試用表

create table Z_TEMP  
(  
  C1 VARCHAR2(10),  
  C2 VARCHAR2(10),  
  C3 VARCHAR2(10)  
);  

--向表中插入3行測試數(shù)據(jù),插入后:

C1         C2         C3  
---------- ---------- ----------  
1                       
2                       
3   

寫了一段過程來測試:

declare  
  v_n number;  
begin  
  update z_temp t set t.c2 = '1' where t.c1 = 1; --更新一行記錄 c1 = 1  
  v_n := sql%rowcount;  
  dbms_output.put_line('第1.0次:' || v_n);  
  commit;  
  v_n := sql%rowcount;  
  dbms_output.put_line('第1.1次:' || v_n);--提交后sql%rowcounty已經(jīng)為0了  
  update z_temp t set t.c2 = '2' where t.c1 = 2; --更新一行記錄 c1 = 2  
  v_n := sql%rowcount;  
  dbms_output.put_line('第2次:' || v_n);  
  update z_temp t set t.c2 = '3'; --更新三行記錄  
  v_n := sql%rowcount;  
  dbms_output.put_line('第3次:' || v_n);  
  commit;  
end;  

/*輸出結果:  

第1.0次:1  

第1.1次:0  

第2次:1  

第3次:3  

*/  

執(zhí)行后表中數(shù)據(jù):

C1         C2         C3  
---------- ---------- ----------  
1          3            
2          3            
3          3      

由此可見sql%rowcount只會記錄未被提交的最后一條SQL語句的影響行數(shù)。這點很重要,如果想統(tǒng)計多個sql的合計影響行數(shù),就必須在每個sql后面,用一個變量保存當前的sql%rowcount。

到此這篇關于oracle中sql%rowcount的作用的文章就介紹到這了,更多相關oracle sql%rowcount內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論