PL / SQL - Kursor
Pada bab ini, kita akan membahas kursor di PL / SQL. Oracle membuat area memori, yang dikenal sebagai area konteks, untuk memproses pernyataan SQL, yang berisi semua informasi yang diperlukan untuk memproses pernyataan; misalnya, jumlah baris yang diproses, dll.
SEBUAH cursoradalah penunjuk ke area konteks ini. PL / SQL mengontrol area konteks melalui kursor. Kursor menahan baris (satu atau lebih) yang dikembalikan oleh pernyataan SQL. Kumpulan baris yang dipegang kursor disebut sebagaiactive set.
Anda dapat menamai kursor agar dapat dirujuk dalam program untuk mengambil dan memproses baris yang dikembalikan oleh pernyataan SQL, satu per satu. Ada dua jenis kursor -
- Kursor implisit
- Kursor eksplisit
Kursor Tersirat
Kursor implisit secara otomatis dibuat oleh Oracle setiap kali pernyataan SQL dijalankan, ketika tidak ada kursor eksplisit untuk pernyataan tersebut. Pemrogram tidak dapat mengontrol kursor implisit dan informasi di dalamnya.
Setiap kali pernyataan DML (INSERT, UPDATE dan DELETE) dikeluarkan, kursor implisit dikaitkan dengan pernyataan ini. Untuk operasi INSERT, kursor menyimpan data yang perlu disisipkan. Untuk operasi UPDATE dan DELETE, kursor mengidentifikasi baris yang akan terpengaruh.
Dalam PL / SQL, Anda dapat merujuk ke kursor implisit terbaru sebagai SQL cursor, yang selalu memiliki atribut seperti %FOUND, %ISOPEN, %NOTFOUND, dan %ROWCOUNT. Kursor SQL memiliki atribut tambahan,%BULK_ROWCOUNT dan %BULK_EXCEPTIONS, dirancang untuk digunakan dengan FORALLpernyataan. Tabel berikut memberikan deskripsi atribut yang paling sering digunakan -
S.No | Atribut & Deskripsi |
---|---|
1 | %FOUND Mengembalikan TRUE jika pernyataan INSERT, UPDATE, atau DELETE mempengaruhi satu atau beberapa baris atau pernyataan SELECT INTO mengembalikan satu atau beberapa baris. Jika tidak, itu akan mengembalikan FALSE. |
2 | %NOTFOUND Kebalikan logis dari% FOUND. Ini mengembalikan TRUE jika pernyataan INSERT, UPDATE, atau DELETE tidak mempengaruhi baris, atau pernyataan SELECT INTO tidak mengembalikan baris. Jika tidak, itu akan mengembalikan FALSE. |
3 | %ISOPEN Selalu mengembalikan FALSE untuk kursor implisit, karena Oracle menutup kursor SQL secara otomatis setelah menjalankan pernyataan SQL yang terkait. |
4 | %ROWCOUNT Mengembalikan jumlah baris yang dipengaruhi oleh pernyataan INSERT, UPDATE, atau DELETE, atau dikembalikan oleh pernyataan SELECT INTO. |
Atribut kursor SQL apa pun akan diakses sebagai sql%attribute_name seperti yang ditunjukkan di bawah ini pada contoh.
Contoh
Kami akan menggunakan tabel CUSTOMERS yang telah kami buat dan gunakan di bab sebelumnya.
Select * from customers;
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
+----+----------+-----+-----------+----------+
Program berikut akan memperbarui tabel dan meningkatkan gaji setiap pelanggan sebesar 500 dan menggunakan SQL%ROWCOUNT atribut untuk menentukan jumlah baris yang terpengaruh -
DECLARE
total_rows number(2);
BEGIN
UPDATE customers
SET salary = salary + 500;
IF sql%notfound THEN
dbms_output.put_line('no customers selected');
ELSIF sql%found THEN
total_rows := sql%rowcount;
dbms_output.put_line( total_rows || ' customers selected ');
END IF;
END;
/
Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -
6 customers selected
PL/SQL procedure successfully completed.
Jika Anda memeriksa catatan di tabel pelanggan, Anda akan menemukan bahwa baris telah diperbarui -
Select * from customers;
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2500.00 |
| 2 | Khilan | 25 | Delhi | 2000.00 |
| 3 | kaushik | 23 | Kota | 2500.00 |
| 4 | Chaitali | 25 | Mumbai | 7000.00 |
| 5 | Hardik | 27 | Bhopal | 9000.00 |
| 6 | Komal | 22 | MP | 5000.00 |
+----+----------+-----+-----------+----------+
Kursor Eksplisit
Kursor eksplisit adalah kursor yang ditentukan oleh programmer untuk mendapatkan kontrol lebih besar atas context area. Kursor eksplisit harus ditentukan di bagian deklarasi Blok PL / SQL. Itu dibuat pada Pernyataan SELECT yang mengembalikan lebih dari satu baris.
Sintaks untuk membuat kursor eksplisit adalah -
CURSOR cursor_name IS select_statement;
Bekerja dengan kursor eksplisit mencakup langkah-langkah berikut -
- Mendeklarasikan kursor untuk menginisialisasi memori
- Membuka kursor untuk mengalokasikan memori
- Mengambil kursor untuk mengambil data
- Menutup kursor untuk melepaskan memori yang dialokasikan
Mendeklarasikan Kursor
Mendeklarasikan kursor mendefinisikan kursor dengan nama dan pernyataan SELECT terkait. Misalnya -
CURSOR c_customers IS
SELECT id, name, address FROM customers;
Membuka Kursor
Membuka kursor akan mengalokasikan memori untuk kursor dan membuatnya siap untuk mengambil baris yang dikembalikan oleh pernyataan SQL ke dalamnya. Misalnya, kita akan membuka kursor yang ditentukan di atas sebagai berikut -
OPEN c_customers;
Mengambil Kursor
Mengambil kursor melibatkan mengakses satu baris dalam satu waktu. Misalnya, kami akan mengambil baris dari kursor yang dibuka di atas sebagai berikut -
FETCH c_customers INTO c_id, c_name, c_addr;
Menutup Kursor
Menutup kursor berarti melepaskan memori yang dialokasikan. Misalnya, kami akan menutup kursor yang dibuka di atas sebagai berikut -
CLOSE c_customers;
Contoh
Berikut adalah contoh lengkap untuk mengilustrasikan konsep kursor eksplisit & minua;
DECLARE
c_id customers.id%type;
c_name customer.name%type;
c_addr customers.address%type;
CURSOR c_customers is
SELECT id, name, address FROM customers;
BEGIN
OPEN c_customers;
LOOP
FETCH c_customers into c_id, c_name, c_addr;
EXIT WHEN c_customers%notfound;
dbms_output.put_line(c_id || ' ' || c_name || ' ' || c_addr);
END LOOP;
CLOSE c_customers;
END;
/
Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -
1 Ramesh Ahmedabad
2 Khilan Delhi
3 kaushik Kota
4 Chaitali Mumbai
5 Hardik Bhopal
6 Komal MP
PL/SQL procedure successfully completed.