oracle中sql%rowcount的作用詳解
起因:新開發(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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Oracle學習記錄之使用自定義函數(shù)和觸發(fā)器實現(xiàn)主鍵動態(tài)生成
這篇文章主要介紹了Oracle學習記錄之使用自定義函數(shù)和觸發(fā)器實現(xiàn)主鍵動態(tài)生成,需要的朋友可以參考下2015-11-11oracle中l(wèi)eft join和right join的區(qū)別淺談
oracle中l(wèi)eft join和right join的區(qū)別淺談,需要的朋友可以參考一下2013-02-02Oracle數(shù)據(jù)IMP和EXP命令用法詳解
這篇文章主要給大家介紹了關于Oracle數(shù)據(jù)IMP和EXP命令用法詳解的相關資料,我們可以使用Oracle自帶的exp、imp命令來進行數(shù)據(jù)庫備份,imp和exp稱之為導入導出,這種方式也能快速的導入導出table或數(shù)據(jù)庫,需要的朋友可以參考下2023-11-11Linux系統(tǒng)下Oracle數(shù)據(jù)庫的安裝和啟動關閉操作教程
這篇文章主要介紹了Linux系統(tǒng)下Oracle數(shù)據(jù)庫的安裝和啟動關閉操作教程,并針對在sqlplus下所需執(zhí)行的命令進行講解,需要的朋友可以參考下2015-12-12Oracle數(shù)據(jù)庫用戶的密碼過期時間如何修改為永不過期
Oracle的密碼過期規(guī)則是用Profile來管理的,系統(tǒng)默認只有一個Profile(DEFAULT),該profile的密碼過期規(guī)則為180天。那么如何修改Oracle數(shù)據(jù)庫用戶的密碼過期時間為永不過期呢?下面通過本文給大家介紹下2017-01-01Oracle數(shù)據(jù)庫實現(xiàn)主鍵字段自增的常用方法
在 Oracle 數(shù)據(jù)庫中,實現(xiàn)主鍵字段的自增功能對于確保數(shù)據(jù)的唯一性和簡化數(shù)據(jù)插入操作非常重要,本文將介紹如何在 Oracle 數(shù)據(jù)庫中實現(xiàn)主鍵字段的自增,提供幾種常見的方法供參考2023-10-10