欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT)

 更新時(shí)間:2020年10月21日 11:32:07   作者:Marydon  
這篇文章主要介紹了Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT),幫助大家更好的理解和使用Oracle數(shù)據(jù)庫(kù),感興趣的朋友可以了解下

1.情景展示

  Oracle 遍歷游標(biāo)的四種方式(for、fetch、while、bulk collect+forall)

2.問(wèn)題分析

  我們可以把游標(biāo)想象成一張表,想要遍歷游標(biāo),就要取到游標(biāo)的每行數(shù)據(jù),所以問(wèn)題的關(guān)鍵就成了:如何取到行數(shù)據(jù)?

3.解決方案

  方式一:FOR 循環(huán)(推薦使用)

  變形一:遍歷顯式游標(biāo)

/* 如果是在存儲(chǔ)過(guò)程外使用顯式游標(biāo),需要使用DECLARE關(guān)鍵字 */
DECLARE
  /*創(chuàng)建游標(biāo)*/
  CURSOR CUR_FIRST_INDEX IS
    SELECT A.ID        A_ID, --一級(jí)指標(biāo)ID
           A.INDEXNAME A_INDEXNAME --一級(jí)指標(biāo)名稱
      FROM INDEX_A A
     ORDER BY A_ID;
  /*定義游標(biāo)變量,該變量的類型為基于游標(biāo)CUR_FIRST_INDEX的行記錄*/
  ROW_CUR_FIRST_INDEX CUR_FIRST_INDEX%ROWTYPE;
/*游標(biāo)處理*/
BEGIN
  /*遍歷顯式游標(biāo)*/
  --FOR 循環(huán)
  FOR ROW_CUR_FIRST_INDEX IN CUR_FIRST_INDEX LOOP
    --循環(huán)體
    DBMS_OUTPUT.PUT_LINE('{"ID":"' || ROW_CUR_FIRST_INDEX.A_ID || '","名稱":"' || ROW_CUR_FIRST_INDEX.A_INDEXNAME || '"}');
  END LOOP;
END;  

  執(zhí)行,輸出結(jié)果

  變形二:遍歷隱式游標(biāo)(推薦使用)

  for循環(huán)遍歷游標(biāo),其實(shí)又可以分為兩種方式,一種是顯式游標(biāo)的遍歷,另一種是隱式游標(biāo)的遍歷。

/* 如果是在存儲(chǔ)過(guò)程外使用隱式游標(biāo),如果用不到變量無(wú)需聲明DECLARE關(guān)鍵字 */
/*游標(biāo)處理*/
BEGIN
  /*遍歷隱式游標(biāo)*/
  --FOR 循環(huán)
  FOR ROW_CUR_FIRST_INDEX IN (SELECT A.ID        A_ID, --一級(jí)指標(biāo)ID
                                     A.INDEXNAME A_INDEXNAME --一級(jí)指標(biāo)名稱
                                FROM INDEX_A A
                               ORDER BY A_ID) LOOP
    --循環(huán)體
    DBMS_OUTPUT.PUT_LINE('{"ID":"' || ROW_CUR_FIRST_INDEX.A_ID || '","名稱":"' || ROW_CUR_FIRST_INDEX.A_INDEXNAME || '"}');
  END LOOP;
END;

  隱式游標(biāo)相較于顯式游標(biāo)用法更加簡(jiǎn)單,無(wú)需聲明直接調(diào)用即可。    

  方式二:FETCH 循環(huán)

/*游標(biāo)聲明代碼和方式一一致,此處省略,直接展示游標(biāo)處理代碼*/
BEGIN
  /*遍歷游標(biāo)*/
  --FETCH 循環(huán)
  OPEN CUR_FIRST_INDEX; --必須要明確的打開和關(guān)閉游標(biāo)
  LOOP
    FETCH CUR_FIRST_INDEX INTO ROW_CUR_FIRST_INDEX;
    EXIT WHEN CUR_FIRST_INDEX%NOTFOUND;
    --循環(huán)體
    DBMS_OUTPUT.PUT_LINE('{"ID":"' || ROW_CUR_FIRST_INDEX.A_ID || '","名稱":"' || ROW_CUR_FIRST_INDEX.A_INDEXNAME || '"}');
  END LOOP;
  CLOSE CUR_FIRST_INDEX;
END;

  方式三:WHILE 循環(huán)

/*游標(biāo)聲明代碼和方式一一致,此處省略,直接展示游標(biāo)處理代碼*/
BEGIN
  /*遍歷游標(biāo)*/
  OPEN CUR_FIRST_INDEX; --必須要明確的打開和關(guān)閉游標(biāo)
  FETCH CUR_FIRST_INDEX
    INTO ROW_CUR_FIRST_INDEX;
  WHILE CUR_FIRST_INDEX%FOUND LOOP
    --循環(huán)體
    DBMS_OUTPUT.PUT_LINE('{"ID":"' || ROW_CUR_FIRST_INDEX.A_ID || '","名稱":"' || ROW_CUR_FIRST_INDEX.A_INDEXNAME || '"}');
    FETCH CUR_FIRST_INDEX
      INTO ROW_CUR_FIRST_INDEX;
  END LOOP;
  CLOSE CUR_FIRST_INDEX;
END;  

  注意:使用while循環(huán)時(shí),需要fetch兩次。

  方式四:BULK COLLECT+FORALL(速度最快)

/* 如果是在存儲(chǔ)過(guò)程外使用顯示游標(biāo),需要使用DECLARE關(guān)鍵字 */
/*聲明游標(biāo)*/
DECLARE
  /*創(chuàng)建顯式游標(biāo)*/
  CURSOR CUR_FIRST_INDEX IS
    SELECT A.ID        A_ID, --一級(jí)指標(biāo)ID
           A.INDEXNAME A_INDEXNAME --一級(jí)指標(biāo)名稱
      FROM INDEX_A A
     ORDER BY A_ID;
  /*定義表類型,該表的表結(jié)構(gòu)為游標(biāo)CUR_FIRST_INDEX的行記錄(可以存儲(chǔ)多條游標(biāo)記錄)*/
  TYPE TABLE_CUR_FIRST_INDEX IS TABLE OF CUR_FIRST_INDEX%ROWTYPE;
  /* 聲明表變量*/
  TAB_FIRST_INDEX TABLE_CUR_FIRST_INDEX;
/*游標(biāo)處理過(guò)程*/
BEGIN
  /*遍歷游標(biāo)*/
  OPEN CUR_FIRST_INDEX;
  LOOP
    --將n行游標(biāo)數(shù)據(jù)放到表中
    FETCH CUR_FIRST_INDEX BULK COLLECT
      INTO TAB_FIRST_INDEX LIMIT 1; -- 數(shù)據(jù)量太少,僅當(dāng)前測(cè)試使用哦,實(shí)際開發(fā)建議 500 左右
    -- 退出條件
    EXIT WHEN TAB_FIRST_INDEX.COUNT = 0;
    --循環(huán)表數(shù)據(jù)
    FORALL I IN TAB_FIRST_INDEX.FIRST .. TAB_FIRST_INDEX.LAST LOOP
      DBMS_OUTPUT.PUT_LINE('{"ID":"' || TAB_FIRST_INDEX(I).A_ID || '","名稱":"' || TAB_FIRST_INDEX(I).A_INDEXNAME || '"}');
    END LOOP;
  END LOOP;
  CLOSE CUR_FIRST_INDEX;
END;

4.總結(jié)

  •   使用for循環(huán)的優(yōu)勢(shì)在于:

  不需要手動(dòng)打開&關(guān)閉游標(biāo)(聲明游標(biāo)的開啟和關(guān)閉);

  不需要手動(dòng)捕獲數(shù)據(jù)(自動(dòng)將數(shù)據(jù)fetch到記錄型變量);

  不需要關(guān)注何時(shí)要退出,也就是不需要寫退出循環(huán)的滿足條件(遍歷完成就會(huì)退出)。

  •   第4方式與前3種的區(qū)別在于:

  前三種的游標(biāo)變量:ROW_CUR_FIRST_INDEX,只能存儲(chǔ)游標(biāo)的一條數(shù)據(jù);

  第四種的表變量:TAB_FIRST_INDEX,可以存儲(chǔ)游標(biāo)的多條數(shù)據(jù)。

  大數(shù)據(jù)批量處理的時(shí)候,第4種方式的優(yōu)勢(shì)將會(huì)凸顯出來(lái)。

本文作者:Marydon

原文鏈接:https://www.cnblogs.com/Marydon20170307/p/12869692.html

以上就是Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT)的詳細(xì)內(nèi)容,更多關(guān)于Oracle 遍歷游標(biāo)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • oracle刪除數(shù)據(jù)但表空間占用率沒(méi)有減小的情況

    oracle刪除數(shù)據(jù)但表空間占用率沒(méi)有減小的情況

    這篇文章主要介紹了oracle刪除數(shù)據(jù)但表空間占用率沒(méi)有減小的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Oracle歸檔日志爆滿問(wèn)題的處理方法

    Oracle歸檔日志爆滿問(wèn)題的處理方法

    Oracle歸檔日志(Archivelog)是Oracle數(shù)據(jù)庫(kù)的一種特性,它主要用于數(shù)據(jù)恢復(fù)和高可用性的目的,但有什么經(jīng)常會(huì)出現(xiàn)無(wú)法連接,手動(dòng)清除歸檔日志后可以恢復(fù)訪問(wèn),但是過(guò)不了幾天依舊會(huì)爆滿,所以本文給大家介紹了Oracle歸檔日志爆滿問(wèn)題的處理方法,需要的朋友可以參考下
    2024-10-10
  • 一文掌握Oracle中的Dual系統(tǒng)表

    一文掌握Oracle中的Dual系統(tǒng)表

    Dual表是Oracle提供的最小的工作表(其實(shí)是一種虛擬表),是sys用戶下的一張內(nèi)部表,只有一行一列(一列:DUMMY,一列:DUMMY,其數(shù)據(jù)類型為:VARCHAR2(1)),接下來(lái)通過(guò)本文給大家分享Oracle中的Dual系統(tǒng)表,需要的朋友可以參考下
    2022-09-09
  • SQL PLUS基本命令的使用方法示例

    SQL PLUS基本命令的使用方法示例

    這篇文章主要給大家介紹了關(guān)于SQL PLUS基本命令的使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Oracle AS關(guān)鍵字 提示錯(cuò)誤

    Oracle AS關(guān)鍵字 提示錯(cuò)誤

    今天運(yùn)行程序時(shí),在Oracle中輸入SQL語(yǔ)句:select * from USERS as u ,程序報(bào)錯(cuò)
    2011-04-04
  • Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2)

    Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2)

    這篇文章主要介紹了Oracle導(dǎo)出文本文件的三種方法(spool,UTL_FILE,sqluldr2),需要的朋友可以參考下
    2023-05-05
  • Oracle?listagg去重distinct的三種方式總結(jié)

    Oracle?listagg去重distinct的三種方式總結(jié)

    這篇文章主要介紹了Oracle?listagg去重distinct的三種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • oracle中誤刪除表后恢復(fù)語(yǔ)句(FLASHBACK)

    oracle中誤刪除表后恢復(fù)語(yǔ)句(FLASHBACK)

    在操作過(guò)程中難免會(huì)誤操作,出現(xiàn)這種情況應(yīng)該怎樣解決呢?不要著急,下面與大家分享下誤刪的恢復(fù)語(yǔ)句
    2013-06-06
  • ORACLE數(shù)據(jù)庫(kù)空間整理心得

    ORACLE數(shù)據(jù)庫(kù)空間整理心得

    ORACLE數(shù)據(jù)庫(kù)空間整理心得...
    2007-03-03
  • Oracle 9i輕松取得建表和索引的DDL語(yǔ)句

    Oracle 9i輕松取得建表和索引的DDL語(yǔ)句

    Oracle 9i輕松取得建表和索引的DDL語(yǔ)句...
    2007-03-03

最新評(píng)論