Oracle 游標

游標(cursor)

游標能夠根據(jù)查詢條件從數(shù)據(jù)表中提取一組記錄或粮,將其作為一個臨時表置于數(shù)據(jù)緩沖區(qū)中,利用指針逐行對記錄數(shù)據(jù)進行操作捞高。

Oracle中的游標分為顯示游標和隱式游標 氯材。

隱式游標

在執(zhí)行SQL語句時,Oracle會自動創(chuàng)建隱式游標硝岗,該游標是內(nèi)存中處理該語句的數(shù)據(jù)緩沖區(qū)氢哮,存儲了執(zhí)行SQL語句的結(jié)果。通過隱式游標屬性可獲知SQL語句的執(zhí)行狀態(tài)信息型檀。

%found:布爾型屬性冗尤,如果sql語句至少影響到一行數(shù)據(jù),值為true,否則為false裂七。

%notfound:布爾型屬性皆看,與%found相反。

%rowcount:數(shù)字型屬性背零,返回受sql影響的行數(shù)腰吟。

%isopen:布爾型屬性,當(dāng)游標已經(jīng)打開時返回true徙瓶,游標關(guān)閉時則為false毛雇。

顯式游標

用戶可以顯式定義游標。使用顯式游標處理數(shù)據(jù)要4個步驟:定義游標倍啥、打開游標禾乘、提取游標數(shù)據(jù)和關(guān)閉游標。

1.定義游標

游標由游標名稱和游標對應(yīng)的select結(jié)果集組成虽缕。定義游標應(yīng)該放在pl/sql程序塊的聲明部分始藕。

語法格式:cursor 游標名稱(參數(shù)) is 查詢語句

2.打開游標

打開游標時,游標會將符合條件的記錄送入數(shù)據(jù)緩沖區(qū)氮趋,并將指針指向第一條記錄伍派。

語法格式:open 游標名稱(參數(shù));

3.提取游標數(shù)據(jù)

將游標中的當(dāng)前行數(shù)據(jù)賦給指定的變量或記錄變量。

語法格式:fetch 游標名稱 into 變量名;

4.關(guān)閉游標

游標一旦使用完畢剩胁,就應(yīng)將其關(guān)閉诉植,釋放與游標相關(guān)聯(lián)的資源。

語法格式:close 游標名稱;

遍歷游標

第一種:loop

declare

cursor c1 is? select sno,cno,grade from sc;

v_sno sc.sno%type;

v_cno sc.cno%type;

v_grade sc.grade%type;

begin

open c1;

loop

? ???? fetch c1 into v_sno,v_cno,v_grade;

? ???? exit when c1%notfound;--緊跟fetch之后

? if c1%found then

? ? ???? dbms_output.put_line(to_char(c1%rowcount)||v_cno);

? end if;

end loop;

close c1;?

end;


第二種:while

declare

cursor c1 is select sno,cno,grade from sc;

v_sno sc.sno%type;

v_cno sc.cno%type;

v_grade sc.grade%type;

begin

open c1;

????fetch c1 into v_sno,v_cno,v_grade;

????while c1%found loop

? ???? dbms_output.put_line(v_sno||v_cno||v_grade);

? ? ?fetch c1 into v_sno,v_cno,v_grade;

end loop;

close c1;?

end;

第三種:for

declare

cursor c1 is select sno,cno,grade from sc;

begin

? for item in c1 loop

? ? dbms_output.put_line(rpad(item.sno,'10',' ')||rpad(item.cno,'10',' ')||rpad(item.grade,'10',' '));

? end loop;

end;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末昵观,一起剝皮案震驚了整個濱河市晾腔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件硫痰,死亡現(xiàn)場離奇詭異,居然都是意外死亡剔应,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門语御,熙熙樓的掌柜王于貴愁眉苦臉地迎上來峻贮,“玉大人,你說我怎么就攤上這事应闯∠丝兀” “怎么了?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵碉纺,是天一觀的道長嚼黔。 經(jīng)常有香客問我细层,道長惜辑,這世上最難降的妖魔是什么唬涧? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮盛撑,結(jié)果婚禮上碎节,老公的妹妹穿的比我還像新娘。我一直安慰自己抵卫,他們只是感情好狮荔,可當(dāng)我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著介粘,像睡著了一般殖氏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上姻采,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天雅采,我揣著相機與錄音,去河邊找鬼慨亲。 笑死婚瓜,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的刑棵。 我是一名探鬼主播巴刻,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼蛉签!你這毒婦竟也來了胡陪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤碍舍,失蹤者是張志新(化名)和其女友劉穎柠座,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體乒验,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡愚隧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了锻全。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狂塘。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖鳄厌,靈堂內(nèi)的尸體忽然破棺而出荞胡,到底是詐尸還是另有隱情,我是刑警寧澤了嚎,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布泪漂,位于F島的核電站廊营,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏萝勤。R本人自食惡果不足惜露筒,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望敌卓。 院中可真熱鬧慎式,春花似錦、人聲如沸趟径。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蜗巧。三九已至掌眠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間幕屹,已是汗流浹背蓝丙。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留香嗓,地道東北人迅腔。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像靠娱,于是被迫代替她去往敵國和親沧烈。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容

  • ORACLE自學(xué)教程 --create tabletestone ( id number, --序號usernam...
    落葉寂聊閱讀 1,081評論 0 0
  • 聲明游標:declare cursor cursor_name(游標名)is select_statement(查...
    夜空中的星H閱讀 169評論 1 0
  • 2019-05-13 游標(cursor)能夠根據(jù)查詢條件從數(shù)據(jù)表中提取一組記錄像云,將其作為一個臨時表置于數(shù)據(jù)緩沖區(qū)...
    Mr_J316閱讀 4,127評論 0 0
  • Oracle游標的關(guān)鍵子CURSOR,用來定義查詢出來的數(shù)據(jù)集锌雀,把內(nèi)存中的數(shù)據(jù)通過游標一條一條的循環(huán)取出。 游標種...
    Yinawake閱讀 329評論 0 2
  • 1.存儲過程簡述 存儲過程:它是大型數(shù)據(jù)庫中常用的迅诬、一組為了完成特定功能的SQL語句集腋逆。 存儲過程在Oracl中是...
    流淚海棠閱讀 1,230評論 0 1