日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

oracle查询游标行数,如何查找Oracle PL/SQL游标中的记录数量?

發(fā)布時間:2025/3/21 数据库 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle查询游标行数,如何查找Oracle PL/SQL游标中的记录数量? 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

NB:我剛才重讀你的問題..你要失敗的。如果只有1個記錄.. 我會后在某一時刻有新的更新..

,讓我們開始在這里..

從的Oracle?數(shù)據(jù)庫PL/SQL用戶指南和參考 10g第2版(10.2) 型號B14261-01 reference

所有行在你打開游標(biāo)時重新鎖定,而不是在取出游標(biāo)時鎖定。當(dāng)您提交或回滾事務(wù)時,這些行將被解鎖。由于行不再被鎖定,所以在提交后無法從FOR UPDATE游標(biāo)讀取。

所以你不需要擔(dān)心記錄解鎖。

所以試試這個..

declare

CURSOR mytable_cur IS SELECT * FROM MY_TABLE WHERE SALARY < 50000 FOR UPDATE;

TYPE mytable_tt IS TABLE OF mytable_cur %ROWTYPE

INDEX BY PLS_INTEGER;

l_my_table_recs mytable_tt;

l_totalcount NUMBER;

begin

OPEN mytable_cur ;

l_totalcount := 0;

LOOP

FETCH mytable_cur

BULK COLLECT INTO l_my_table_recs LIMIT 100;

l_totalcount := l_totalcount + NVL(l_my_table_recs.COUNT,0);

--this is the check for only 1 row..

EXIT WHEN l_totalcount < 2;

FOR indx IN 1 .. l_my_table_recs.COUNT

LOOP

--process each record.. via l_my_table_recs (indx)

END LOOP;

EXIT WHEN mytable_cur%NOTFOUND;

END LOOP;

CLOSE mytable_cur ;

end;

ALTERNATE ANSWER 我看了你的答案向后啟動,以為你想退出,如果有更多的則1排..不是正好有一個。所以這是我以前的答案。

2個簡單的方法來檢查只有1條記錄。

選項(xiàng)1 - 顯式去抓取

declare

CURSOR C1 IS SELECT * FROM MY_TABLE WHERE SALARY < 50000 FOR UPDATE;

l_my_table_rec C1%rowtype;

l_my_table_rec2 C1%rowtype;

begin

open C1;

fetch c1 into l_my_table_rec;

if c1%NOTFOUND then

--no data found

end if;

fetch c1 into l_my_table_rec2;

if c1%FOUND THEN

--i have more then 1 row

end if;

close c1;

-- processing logic

end;

我希望你的想法。

選擇2 - 異常捕獲

declare

CURSOR C1 IS SELECT * FROM MY_TABLE WHERE SALARY < 50000 FOR UPDATE;

l_my_table_rec C1%rowtype;

begin

begin

select *

from my_table

into l_my_table_rec

where salary < 50000

for update;

exception

when too_many_rows then

-- handle the exception where more than one row is returned

when no_data_found then

-- handle the exception where no rows are returned

when others then raise;

end;

-- processing logic

end;

此外 記住:用顯式游標(biāo)..你可以%鍵入您的變量關(guān)閉光標(biāo)記錄而不是原始表。

當(dāng)您在查詢中加入時,這特別有用。

此外,rememebr您可以用

UPDATE table_name

SET set_clause

WHERE CURRENT OF cursor_name;

類型語句更新表中的行,但我認(rèn)為如果你還沒有“獲取”第二行只會工作..

有關(guān)游標(biāo)FOR循環(huán)一些更多的信息.??.嘗試 Here

總結(jié)

以上是生活随笔為你收集整理的oracle查询游标行数,如何查找Oracle PL/SQL游标中的记录数量?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。