久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

oracle中sql%rowcount的作用詳解

瀏覽:173日期:2023-09-22 20:54:42

起因:新開(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

主站蜘蛛池模板: 天门市| 定安县| 靖江市| 右玉县| 浪卡子县| 东平县| 沅江市| 吴忠市| 五常市| 莱阳市| 金门县| 鄢陵县| 横峰县| 自治县| 女性| 凌海市| 图片| 灵川县| 丹巴县| 内黄县| 谷城县| 全椒县| 东海县| 丹东市| 固始县| 苗栗县| 平昌县| 黄石市| 镇雄县| 闵行区| 元阳县| 自贡市| 奉贤区| 沁源县| 虞城县| 柘荣县| 星子县| 江华| 鄂托克前旗| 察哈| 太谷县|