PL / SQL - Loop

Pada bab ini, kita akan membahas Loops di PL / SQL. Mungkin ada situasi ketika Anda perlu mengeksekusi blok kode beberapa kali. Secara umum, pernyataan dieksekusi secara berurutan: Pernyataan pertama dalam suatu fungsi dijalankan pertama, diikuti oleh yang kedua, dan seterusnya.

Bahasa pemrograman menyediakan berbagai struktur kontrol yang memungkinkan jalur eksekusi yang lebih rumit.

Pernyataan loop memungkinkan kita untuk mengeksekusi pernyataan atau sekelompok pernyataan beberapa kali dan berikut adalah bentuk umum dari pernyataan loop di sebagian besar bahasa pemrograman -

PL / SQL menyediakan jenis loop berikut untuk menangani persyaratan perulangan. Klik tautan berikut untuk memeriksa detailnya.

S.No Jenis & Deskripsi Loop
1 PL / SQL LOOP Dasar

Dalam struktur loop ini, urutan pernyataan diapit antara pernyataan LOOP dan END LOOP. Pada setiap iterasi, urutan pernyataan dijalankan dan kemudian kontrol dilanjutkan di bagian atas loop.

2 PL / SQL WHILE LOOP

Mengulangi pernyataan atau sekelompok pernyataan saat kondisi tertentu benar. Ini menguji kondisi sebelum menjalankan badan perulangan.

3 PL / SQL UNTUK LOOP

Jalankan urutan pernyataan beberapa kali dan singkatkan kode yang mengelola variabel loop.

4 Loop bersarang di PL / SQL

Anda dapat menggunakan satu atau lebih loop di dalam loop dasar lainnya, while, atau for loop.

Memberi label pada PL / SQL Loop

Loop PL / SQL dapat diberi label. Label harus diapit oleh tanda kurung sudut ganda (<< dan >>) dan muncul di awal pernyataan LOOP. Nama label juga dapat muncul di akhir pernyataan LOOP. Anda dapat menggunakan label dalam pernyataan EXIT untuk keluar dari loop.

Program berikut menggambarkan konsep -

DECLARE 
   i number(1); 
   j number(1); 
BEGIN 
   << outer_loop >> 
   FOR i IN 1..3 LOOP 
      << inner_loop >> 
      FOR j IN 1..3 LOOP 
         dbms_output.put_line('i is: '|| i || ' and j is: ' || j); 
      END loop inner_loop; 
   END loop outer_loop; 
END; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

i is: 1 and j is: 1 
i is: 1 and j is: 2 
i is: 1 and j is: 3 
i is: 2 and j is: 1 
i is: 2 and j is: 2 
i is: 2 and j is: 3 
i is: 3 and j is: 1 
i is: 3 and j is: 2 
i is: 3 and j is: 3  

PL/SQL procedure successfully completed.

Pernyataan Kontrol Loop

Pernyataan kontrol loop mengubah eksekusi dari urutan normalnya. Saat eksekusi meninggalkan lingkup, semua objek otomatis yang dibuat dalam lingkup itu akan dimusnahkan.

PL / SQL mendukung pernyataan kontrol berikut. Pelabelan loop juga membantu dalam mengambil kontrol di luar loop. Klik tautan berikut untuk memeriksa detailnya.

S.No Pernyataan & Deskripsi Kontrol
1 Pernyataan EXIT

Pernyataan Exit menyelesaikan loop dan kontrol lolos ke pernyataan segera setelah END LOOP.

2 LANJUTKAN pernyataan

Menyebabkan loop melewati sisa tubuhnya dan segera menguji ulang kondisinya sebelum mengulang.

3 Pernyataan GOTO

Transfer kontrol ke pernyataan berlabel. Meskipun tidak disarankan untuk menggunakan pernyataan GOTO dalam program Anda.