oracle中sql%rowcount的作用詳解
起因:新開(kāi)發(fā)個(gè)存儲(chǔ)過(guò)程,需要當(dāng)一個(gè)用戶調(diào)用存儲(chǔ)過(guò)程操作一行數(shù)據(jù)時(shí),另外的用戶不允許調(diào)用過(guò)程操作該數(shù)據(jù)。
解決辦法:先將該記錄的狀態(tài)改為處理中,當(dāng)別的用戶看到為處理中時(shí)則跳出過(guò)程。此時(shí)用到了sql%rowcount來(lái)判斷是否更新了記錄的狀態(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;
由于沒(méi)有用過(guò)sql%rowcount,所以特意測(cè)試了一下,下面是對(duì)sql%rowcount功能的測(cè)試:
--先建個(gè)測(cè)試用表
create table Z_TEMP ( C1 VARCHAR2(10), C2 VARCHAR2(10), C3 VARCHAR2(10) );
--向表中插入3行測(cè)試數(shù)據(jù),插入后:
C1 C2 C3 ---------- ---------- ---------- 1 2 3
寫了一段過(guò)程來(lái)測(cè)試:
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;
/*輸出結(jié)果:
第1.0次:1
第1.1次:0
第2次:1
第3次:3
*/
執(zhí)行后表中數(shù)據(jù):
C1 C2 C3 ---------- ---------- ---------- 1 3 2 3 3 3
由此可見(jiàn)sql%rowcount只會(huì)記錄未被提交的最后一條SQL語(yǔ)句的影響行數(shù)。這點(diǎn)很重要,如果想統(tǒng)計(jì)多個(gè)sql的合計(jì)影響行數(shù),就必須在每個(gè)sql后面,用一個(gè)變量保存當(dāng)前的sql%rowcount。
到此這篇關(guān)于oracle中sql%rowcount的作用的文章就介紹到這了,更多相關(guān)oracle sql%rowcount內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle學(xué)習(xí)記錄之使用自定義函數(shù)和觸發(fā)器實(shí)現(xiàn)主鍵動(dòng)態(tài)生成
這篇文章主要介紹了Oracle學(xué)習(xí)記錄之使用自定義函數(shù)和觸發(fā)器實(shí)現(xiàn)主鍵動(dòng)態(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命令用法詳解
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)IMP和EXP命令用法詳解的相關(guān)資料,我們可以使用Oracle自帶的exp、imp命令來(lái)進(jìn)行數(shù)據(jù)庫(kù)備份,imp和exp稱之為導(dǎo)入導(dǎo)出,這種方式也能快速的導(dǎo)入導(dǎo)出table或數(shù)據(jù)庫(kù),需要的朋友可以參考下2023-11-11Linux系統(tǒng)下Oracle數(shù)據(jù)庫(kù)的安裝和啟動(dòng)關(guān)閉操作教程
這篇文章主要介紹了Linux系統(tǒng)下Oracle數(shù)據(jù)庫(kù)的安裝和啟動(dòng)關(guān)閉操作教程,并針對(duì)在sqlplus下所需執(zhí)行的命令進(jìn)行講解,需要的朋友可以參考下2015-12-12Oracle數(shù)據(jù)庫(kù)用戶的密碼過(guò)期時(shí)間如何修改為永不過(guò)期
Oracle的密碼過(guò)期規(guī)則是用Profile來(lái)管理的,系統(tǒng)默認(rèn)只有一個(gè)Profile(DEFAULT),該profile的密碼過(guò)期規(guī)則為180天。那么如何修改Oracle數(shù)據(jù)庫(kù)用戶的密碼過(guò)期時(shí)間為永不過(guò)期呢?下面通過(guò)本文給大家介紹下2017-01-01Oracle導(dǎo)出導(dǎo)入表結(jié)構(gòu)操作實(shí)戰(zhàn)記錄
在日常數(shù)據(jù)庫(kù)維護(hù)中,經(jīng)常會(huì)遇到導(dǎo)出數(shù)據(jù)表的需求,下面這篇文章主要給大家介紹了關(guān)于Oracle導(dǎo)出導(dǎo)入表結(jié)構(gòu)操作的相關(guān)資料,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-02-02Oracle數(shù)據(jù)庫(kù)實(shí)現(xiàn)主鍵字段自增的常用方法
在 Oracle 數(shù)據(jù)庫(kù)中,實(shí)現(xiàn)主鍵字段的自增功能對(duì)于確保數(shù)據(jù)的唯一性和簡(jiǎn)化數(shù)據(jù)插入操作非常重要,本文將介紹如何在 Oracle 數(shù)據(jù)庫(kù)中實(shí)現(xiàn)主鍵字段的自增,提供幾種常見(jiàn)的方法供參考2023-10-10