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