PL / SQL - Koleksi

Dalam bab ini, kita akan membahas Koleksi di PL / SQL. Koleksi adalah sekelompok elemen yang memiliki tipe data yang sama. Setiap elemen diidentifikasi oleh subskrip unik yang mewakili posisinya dalam koleksi.

PL / SQL menyediakan tiga jenis koleksi -

  • Tabel indeks-menurut atau array asosiatif
  • Tabel bersarang
  • Array ukuran variabel atau Varray

Dokumentasi Oracle menyediakan karakteristik berikut untuk setiap jenis koleksi -

Jenis Koleksi Jumlah Elemen Jenis Subskrip Padat atau Jarang Dimana Dibuat Dapat berupa Atribut Tipe Objek
Array asosiatif (atau tabel indeks-oleh) Tak terbatas String atau integer Antara Hanya di blok PL / SQL Tidak
Tabel bersarang Tak terbatas Bilangan bulat Mulai padat, bisa jadi jarang Baik di blok PL / SQL atau di tingkat skema Iya
Variablesize array (Varray) Terikat Bilangan bulat Selalu padat Baik di blok PL / SQL atau di tingkat skema Iya

Kami telah membahas varray di bab ini 'PL/SQL arrays'. Pada bab ini, kita akan membahas tabel PL / SQL.

Kedua jenis tabel PL / SQL, yaitu tabel index-by dan tabel bersarang memiliki struktur yang sama dan baris-barisnya diakses menggunakan notasi subskrip. Namun, kedua jenis tabel ini berbeda dalam satu aspek; tabel bersarang bisa disimpan dalam kolom database dan tabel indeks-oleh tidak bisa.

Indeks-Berdasarkan Tabel

Sebuah index-by tabel (juga disebut associative array) adalah satu set key-valuepasangan. Setiap kunci unik dan digunakan untuk menemukan nilai yang sesuai. Kuncinya bisa berupa integer atau string.

Tabel indeks-menurut dibuat menggunakan sintaks berikut. Di sini, kami membuat fileindex-by tabel bernama table_name, kunci yang akan menjadi subscript_type dan nilai terkait akan menjadi element_type

TYPE type_name IS TABLE OF element_type [NOT NULL] INDEX BY subscript_type; 
 
table_name type_name;

Contoh

Contoh berikut menunjukkan cara membuat tabel untuk menyimpan nilai integer bersama dengan nama dan kemudian mencetak daftar nama yang sama.

DECLARE 
   TYPE salary IS TABLE OF NUMBER INDEX BY VARCHAR2(20); 
   salary_list salary; 
   name   VARCHAR2(20); 
BEGIN 
   -- adding elements to the table 
   salary_list('Rajnish') := 62000; 
   salary_list('Minakshi') := 75000; 
   salary_list('Martin') := 100000; 
   salary_list('James') := 78000;  
   
   -- printing the table 
   name := salary_list.FIRST; 
   WHILE name IS NOT null LOOP 
      dbms_output.put_line 
      ('Salary of ' || name || ' is ' || TO_CHAR(salary_list(name))); 
      name := salary_list.NEXT(name); 
   END LOOP; 
END; 
/

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

Salary of James is 78000 
Salary of Martin is 100000 
Salary of Minakshi is 75000 
Salary of Rajnish is 62000  

PL/SQL procedure successfully completed.

Contoh

Elemen tabel indeks-dengan juga bisa menjadi %ROWTYPE dari setiap tabel database atau %TYPEdari setiap bidang tabel database. Contoh berikut menggambarkan konsep tersebut. Kami akan menggunakanCUSTOMERS tabel disimpan dalam database kami sebagai -

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 | 
+----+----------+-----+-----------+----------+

DECLARE 
   CURSOR c_customers is 
      select name from customers; 

   TYPE c_list IS TABLE of customers.Name%type INDEX BY binary_integer; 
   name_list c_list; 
   counter integer :=0; 
BEGIN 
   FOR n IN c_customers LOOP 
      counter := counter +1; 
      name_list(counter) := n.name; 
      dbms_output.put_line('Customer('||counter||'):'||name_lis t(counter)); 
   END LOOP; 
END; 
/

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

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal  

PL/SQL procedure successfully completed

Tabel Bersarang

SEBUAH nested tableseperti array satu dimensi dengan jumlah elemen yang berubah-ubah. Namun, tabel bersarang berbeda dari larik dalam aspek berikut -

  • Sebuah array memiliki jumlah elemen yang dideklarasikan, tetapi tabel bertingkat tidak. Ukuran tabel bertingkat dapat meningkat secara dinamis.

  • Sebuah array selalu padat, yaitu selalu memiliki subskrip yang berurutan. Array bersarang awalnya padat, tetapi bisa menjadi jarang ketika elemen dihapus darinya.

Tabel bertingkat dibuat menggunakan sintaks berikut -

TYPE type_name IS TABLE OF element_type [NOT NULL]; 
 
table_name type_name;

Deklarasi ini mirip dengan deklarasi sebuah index-by tabel, tapi tidak ada INDEX BY ayat.

Tabel bersarang dapat disimpan dalam kolom database. Ini selanjutnya dapat digunakan untuk menyederhanakan operasi SQL di mana Anda menggabungkan tabel satu kolom dengan tabel yang lebih besar. Array asosiatif tidak dapat disimpan dalam database.

Contoh

Contoh berikut menggambarkan penggunaan tabel bersarang -

DECLARE 
   TYPE names_table IS TABLE OF VARCHAR2(10); 
   TYPE grades IS TABLE OF INTEGER;  
   names names_table; 
   marks grades; 
   total integer; 
BEGIN 
   names := names_table('Kavita', 'Pritam', 'Ayan', 'Rishav', 'Aziz'); 
   marks:= grades(98, 97, 78, 87, 92); 
   total := names.count; 
   dbms_output.put_line('Total '|| total || ' Students'); 
   FOR i IN 1 .. total LOOP 
      dbms_output.put_line('Student:'||names(i)||', Marks:' || marks(i)); 
   end loop; 
END; 
/

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

Total 5 Students 
Student:Kavita, Marks:98 
Student:Pritam, Marks:97 
Student:Ayan, Marks:78 
Student:Rishav, Marks:87 
Student:Aziz, Marks:92  

PL/SQL procedure successfully completed.

Contoh

Elemen a nested table bisa juga menjadi %ROWTYPEdari setiap tabel database atau% TYPE dari setiap bidang tabel database. Contoh berikut menggambarkan konsep tersebut. Kami akan menggunakan tabel CUSTOMERS yang disimpan dalam database kami sebagai -

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 | 
+----+----------+-----+-----------+----------+

DECLARE 
   CURSOR c_customers is  
      SELECT  name FROM customers;  
   TYPE c_list IS TABLE of customerS.No.ame%type; 
   name_list c_list := c_list(); 
   counter integer :=0; 
BEGIN 
   FOR n IN c_customers LOOP 
      counter := counter +1; 
      name_list.extend; 
      name_list(counter)  := n.name; 
      dbms_output.put_line('Customer('||counter||'):'||name_list(counter)); 
   END LOOP; 
END; 
/

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

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal  

PL/SQL procedure successfully completed.

Metode Pengumpulan

PL / SQL menyediakan metode pengumpulan bawaan yang membuat koleksi lebih mudah digunakan. Tabel berikut mencantumkan metode dan tujuannya -

S.No Nama Metode & Tujuan
1

EXISTS(n)

Mengembalikan TRUE jika elemen ke-n dalam koleksi ada; jika tidak mengembalikan FALSE.

2

COUNT

Mengembalikan jumlah elemen yang saat ini ada dalam koleksi.

3

LIMIT

Memeriksa ukuran maksimal sebuah koleksi.

4

FIRST

Mengembalikan nomor indeks pertama (terkecil) dalam koleksi yang menggunakan langganan integer.

5

LAST

Mengembalikan nomor indeks (terbesar) terakhir dalam koleksi yang menggunakan subskrip integer.

6

PRIOR(n)

Mengembalikan nomor indeks yang mendahului indeks n dalam sebuah koleksi.

7

NEXT(n)

Mengembalikan nomor indeks yang menggantikan indeks n.

8

EXTEND

Menambahkan satu elemen null ke koleksi.

9

EXTEND(n)

Menambahkan n elemen nol ke koleksi.

10

EXTEND(n,i)

Tambahkan nsalinan elemen ke -i ke koleksi.

11

TRIM

Menghapus satu elemen dari akhir koleksi.

12

TRIM(n)

Menghapus n elemen dari akhir koleksi.

13

DELETE

Menghapus semua elemen dari koleksi, menyetel COUNT menjadi 0.

14

DELETE(n)

Menghapus nthelemen dari array asosiatif dengan kunci numerik atau tabel bertingkat. Jika array asosiatif memiliki kunci string, elemen yang sesuai dengan nilai kunci akan dihapus. Jikan adalah nol, DELETE(n) tidak melakukan apa-apa.

15

DELETE(m,n)

Menghapus semua elemen dalam jangkauan m..ndari array asosiatif atau tabel bersarang. Jikam lebih besar dari n atau jika m atau n adalah nol, DELETE(m,n) tidak melakukan apa-apa.

Pengecualian Koleksi

Tabel berikut memberikan pengecualian koleksi dan kapan mereka dimunculkan -

Pengecualian Koleksi Dibesarkan dalam Situasi
COLLECTION_IS_NULL Anda mencoba untuk mengoperasikan koleksi nol secara atomis.
TIDAK ADA DATA DITEMUKAN Subskrip menunjukkan elemen yang telah dihapus, atau elemen yang tidak ada dari array asosiatif.
SUBSCRIPT_BEYOND_COUNT Subskrip melebihi jumlah elemen dalam koleksi.
SUBSCRIPT_OUTSIDE_LIMIT Subskrip berada di luar rentang yang diizinkan.
VALUE_ERROR Subskrip adalah null atau tidak dapat dikonversi ke jenis kunci. Pengecualian ini mungkin terjadi jika kunci didefinisikan sebagai aPLS_INTEGER kisaran, dan subskrip berada di luar kisaran ini.