首頁  >  文章  >  資料庫  >  oracle儲存過程中的循環語句有哪些

oracle儲存過程中的循環語句有哪些

WBOY
WBOY原創
2022-06-10 15:48:1113450瀏覽

oracle預存程​​序中的循環語句:1、LOOP循環,語法為「loop 循環體;EXIT WHEN 結束循環條件表達式;END LOOP;」;2、WHILE循環,語法為「while 條件表達式loop 循環語句;end loop;」;3、for循環,語法為「for 變數IN (reverse) 計數器下限值...計數器上限值LOOP 迴圈體;END LOOP;」。

oracle儲存過程中的循環語句有哪些

本教學操作環境:windows10系統、Oracle 12c版、Dell G3電腦。

oracle預存程​​序中的迴圈語句有哪些

當程式需要重複執行某一操作時,就必須使用循環結構。 PL/SQL 中的迴圈語句主要包括LOOP語句、WHERE語句、FOR語句3種。

LOOP語句

LOOP語句會先執行一次循環體,然後再判斷EXIT WHEN關鍵字後面的條件表達式是ture還是false,為true的時候退出循環體,否則程式將再次執行循環體。

基本語法:

loop
    A;
    EXIT WHEN B;
END LOOP;

A: 代表循環體中的sql語句,可以是一句也可能是多句,這是循環體核心部分,這些語句至少被執行一遍。

B: 循環結束條件表達式,為ture時,退出循環,否則再次執行循環體。

程式碼範例:

-- Created on 2020/12/16 by GUO 
declare 
  i int:= 0;
begin
  loop
    i:=i+1;
    dbms_output.put_line(i);
    EXIT WHEN i > 3;
  END LOOP;
end;

執行結果:

oracle儲存過程中的循環語句有哪些

#實戰範例:

使用Loop 遊標的時候,取遊標當中的值,必須重新賦值一遍,不然會報錯。

-- Created on 2020/12/17 by GUO 
declare
  cursor user is
    select * from user_table;
  user1 user_table%rowtype;
begin
  open user;
  loop
    fetch user into user1;
    exit when user%notfound;
    dbms_output.put_line('用户名称:' || user1.USER_NAME);
    dbms_output.put_line('用户年龄:' || user1.USER_AGE);
  end loop;
  close user; --关闭游标
end;

WHILE語句

在執行之前,首先要判斷條件運算式的值是否為true,true執行迴圈體,否則退出WHILE迴圈,繼續執行循環後面的程式碼。

基本語法:

while a loop
  b;
end loop;

A: 表示一個條件表達式,當值為true時,程式執行循環體,否則退出。

B: 循環體內的sql語句。

程式碼範例:

-- Created on 2020/12/17 by GUO 
declare
  i int := 0;
begin
  while i < 3 loop
    i := i + 1;
    dbms_output.put_line(i);
  end loop;
end;

執行結果:

oracle儲存過程中的循環語句有哪些

#實戰範例:

-- Created on 2020/12/17 by GUO 
declare
  cursor user is
    select * from user_table;
  user1 user_table%rowtype;
begin
  open user;
  fetch user into user1;
  while(user%found)loop
  dbms_output.put_line(&#39;用户名称:&#39; || user1.USER_NAME);
  fetch user into user1;
  end loop;
end;

FOR語句

FOR語句是一個可提前設定循環次數的循環控制語句,它有一個循環計數器,通常是一個整數變量,透過這個計數器來控制循環次數。

基本語法:

for A IN (reverse) B...C LOOP
   D;
 END LOOP;

A: 表示一個變量,通常為證書類型,用來作為計數器,預設值是遞增的,當循環當中使用reverse關鍵字時,就會循環遞減。

B: 計數器下限值,當計數器的值小於下限值的時候,終止迴圈。

C: 計數器上限值,當計數器的值大於上限值的時候,終止迴圈。

D: 迴圈體。

程式碼範例:

-- Created on 2020/12/17 by GUO 
declare 
  i int := 0;
begin
  for i IN reverse 1..5 LOOP
    dbms_output.put_line(i);
  END LOOP;
end;

執行結果:

oracle儲存過程中的循環語句有哪些

#實戰範例:

配合遊標使用

-- Created on 2020/12/17 by GUO 
declare
  cursor user is
    select * from user_table;
begin
  for user1 in user loop
  dbms_output.put_line(&#39;用户名称:&#39;||user1.USER_NAME);
  dbms_output.put_line(&#39;用户年龄:&#39;||user1.USER_AGE);
  end loop;
end;

推薦教學:《Oracle影片教學

#

以上是oracle儲存過程中的循環語句有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn