Oracle游標(biāo)

Oracle游標(biāo)的關(guān)鍵子CURSOR,用來(lái)定義查詢出來(lái)的數(shù)據(jù)集驾孔,把內(nèi)存中的數(shù)據(jù)通過(guò)游標(biāo)一條一條的循環(huán)取出。

游標(biāo)種類(lèi)

  1. 顯示游標(biāo)
    游標(biāo)使用之前必須先聲明炸庞,一般對(duì)查詢語(yǔ)句結(jié)果定義游標(biāo)钱床,然后通過(guò)打開(kāi)游標(biāo)循環(huán)取出結(jié)果集。
  2. 隱式游標(biāo)
    指PL/SQL管理埠居,開(kāi)發(fā)者不能自己控制查牌,只能獲得它的屬性。

顯示游標(biāo)

開(kāi)發(fā)中比較常用

  1. 聲明游標(biāo)
declare cursor cursor_name is select * from xxx;
  1. 打開(kāi)游標(biāo)
open cursor_name;
  1. 讀取游標(biāo)中的數(shù)據(jù)
fetch curos_name into record(變量)
  1. 關(guān)閉游標(biāo)
close cursor_name;

實(shí)例

declare
  --定義游標(biāo)
  cursor cur_xsjbxx is
    select * from stuinfo order by stuid;
  --定義記錄變量  
  ls_curinfo cur_xsjbxx%rowtype;
begin
  open cur_xsjbxx;--打開(kāi)游標(biāo)
  loop
    FETCH cur_xsjbxx
      INTO ls_curinfo;--獲取記錄值
    EXIT WHEN cur_xsjbxx%NOTFOUND;
   
    dbms_output.put_line('學(xué)號(hào):' || ls_curinfo.stuid || ',姓名:' ||
                         ls_curinfo.STUNAME);
  end loop;
  close cur_xsjbxx;--關(guān)閉游標(biāo)
end;

解析:配合loop語(yǔ)句來(lái)循環(huán)打印結(jié)果,通過(guò)游標(biāo)變量%NOTFOUND來(lái)獲取游標(biāo)的結(jié)束滥壕,跳出loop纸颜。

顯式游標(biāo)的屬性

  1. %NOTFOUND.表示游標(biāo)獲是否還能提取數(shù)據(jù)。沒(méi)有數(shù)據(jù)時(shí)返回TRUE绎橘,有數(shù)據(jù)時(shí)返回FALSE胁孙。
  2. %FOUND。與%NOTFOUND相反
  3. %ISOPEN称鳞。判斷游標(biāo)是否打開(kāi)
  4. %ROWCOUNT涮较。表示游標(biāo)FETCH INTO獲取了多少記錄數(shù)。

實(shí)例

declare
  --定義游標(biāo)
  cursor cur_xsjbxx is
    select * from stuinfo order by stuid;
  --定義記錄變量  
  ls_curinfo cur_xsjbxx%rowtype;
begin
  open cur_xsjbxx;--打開(kāi)游標(biāo)
  loop
    FETCH cur_xsjbxx
      INTO ls_curinfo;--獲取記錄值
    EXIT WHEN cur_xsjbxx%NOTFOUND;
    --利用游標(biāo)計(jì)數(shù)器打印學(xué)生個(gè)數(shù)
    dbms_output.put('%rowcount計(jì)數(shù)器冈止,第'||cur_xsjbxx%rowcount||'位學(xué)生狂票,');
    dbms_output.put_line('學(xué)號(hào):' || ls_curinfo.stuid || ',姓名:' ||
                         ls_curinfo.STUNAME);
  end loop;
  close cur_xsjbxx;--關(guān)閉游標(biāo)
end;

隱式游標(biāo)

實(shí)例

declare
  ls_xsjbxx stuinfo%rowtype;
begin
  --查詢學(xué)生信息
  select * into ls_xsjbxx from stuinfo t where t.stuid = 'SC201801001';
  if sql%found then
    dbms_output.put_line('學(xué)號(hào):' || ls_xsjbxx.stuid || ',姓名:' ||
                         ls_xsjbxx.stuname);
  end if;
 
  --查詢學(xué)生信息(不存在的學(xué)生)
  select * into ls_xsjbxx from stuinfo t where t.stuid = 'SC201901001';
  if sql%found then
    dbms_output.put_line('學(xué)號(hào):' || ls_xsjbxx.stuid || ',姓名:' ||
                         ls_xsjbxx.stuname);
  end if;
exception
  when no_data_found then
    dbms_output.put_line('該學(xué)生SC201901001不存在');
end;
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市熙暴,隨后出現(xiàn)的幾起案子闺属,更是在濱河造成了極大的恐慌,老刑警劉巖周霉,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件掂器,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡诗眨,警方通過(guò)查閱死者的電腦和手機(jī)唉匾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)匠楚,“玉大人巍膘,你說(shuō)我怎么就攤上這事∮蟛荆” “怎么了峡懈?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)与斤。 經(jīng)常有香客問(wèn)我肪康,道長(zhǎng)荚恶,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任磷支,我火速辦了婚禮谒撼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雾狈。我一直安慰自己廓潜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布善榛。 她就那樣靜靜地躺著辩蛋,像睡著了一般。 火紅的嫁衣襯著肌膚如雪移盆。 梳的紋絲不亂的頭發(fā)上悼院,一...
    開(kāi)封第一講書(shū)人閱讀 51,462評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音咒循,去河邊找鬼据途。 笑死,一個(gè)胖子當(dāng)著我的面吹牛剑鞍,可吹牛的內(nèi)容都是我干的昨凡。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼蚁署,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼便脊!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起光戈,我...
    開(kāi)封第一講書(shū)人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤哪痰,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后久妆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體晌杰,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年筷弦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了肋演。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡烂琴,死狀恐怖爹殊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情奸绷,我是刑警寧澤梗夸,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站号醉,受9級(jí)特大地震影響反症,放射性物質(zhì)發(fā)生泄漏辛块。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一铅碍、第九天 我趴在偏房一處隱蔽的房頂上張望润绵。 院中可真熱鬧,春花似錦胞谈、人聲如沸授药。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至莱衩,卻和暖如春爵嗅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背笨蚁。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工睹晒, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人括细。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓伪很,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親奋单。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锉试,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

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

  • 2019-05-13 游標(biāo)(cursor)能夠根據(jù)查詢條件從數(shù)據(jù)表中提取一組記錄,將其作為一個(gè)臨時(shí)表置于數(shù)據(jù)緩沖區(qū)...
    Mr_J316閱讀 4,127評(píng)論 0 0
  • 前言 厚積而薄發(fā)览濒。 在 PL/SQL 程序中呆盖,對(duì)于處理多行記錄的事務(wù)經(jīng)常使用游標(biāo)來(lái)實(shí)現(xiàn)。 游標(biāo)的概念 --為了處理...
    olaH閱讀 998評(píng)論 0 4
  • 游標(biāo)是一種 PL/SQL 控制結(jié)構(gòu);可以對(duì) SQL 語(yǔ)句的處理進(jìn)行顯示控制乏苦,便于對(duì)表的行數(shù)據(jù)逐條進(jìn)行處理株扛。 游標(biāo)并...
    小母牛不生產(chǎn)奶閱讀 398評(píng)論 0 0
  • 1、Check規(guī)則 Check (Agebetween15and30 )把年齡限制在15~30歲之間 2汇荐、新SQL...
    姜海濤閱讀 826評(píng)論 0 4
  • 一洞就、簡(jiǎn)介 1、游標(biāo)的概念 游標(biāo)(Cursor) 就是一個(gè)變動(dòng)的光標(biāo)拢驾,它本質(zhì)上是一個(gè)指針奖磁,指向從數(shù)據(jù)庫(kù)查詢出來(lái)的結(jié)果...
    滴滴滴9527閱讀 2,037評(píng)論 0 1