PL / SQL - Panduan Cepat

Bahasa pemrograman PL / SQL dikembangkan oleh Oracle Corporation pada akhir 1980-an sebagai bahasa ekstensi prosedural untuk SQL dan database relasional Oracle. Berikut adalah fakta penting tertentu tentang PL / SQL -

  • PL / SQL adalah bahasa pemrosesan transaksi yang sepenuhnya portabel dan berkinerja tinggi.

  • PL / SQL menyediakan lingkungan pemrograman independen OS bawaan, ditafsirkan dan.

  • PL / SQL juga bisa langsung dipanggil dari baris perintah SQL*Plus interface.

  • Panggilan langsung juga dapat dilakukan dari panggilan bahasa pemrograman eksternal ke database.

  • Sintaks umum PL / SQL didasarkan pada ADA dan bahasa pemrograman Pascal.

  • Selain Oracle, PL / SQL tersedia dalam format TimesTen in-memory database dan IBM DB2.

Fitur PL / SQL

PL / SQL memiliki beberapa fitur berikut -

  • PL / SQL terintegrasi erat dengan SQL.
  • Ini menawarkan pemeriksaan kesalahan ekstensif.
  • Ini menawarkan berbagai tipe data.
  • Ini menawarkan berbagai struktur pemrograman.
  • Ini mendukung pemrograman terstruktur melalui fungsi dan prosedur.
  • Ini mendukung pemrograman berorientasi objek.
  • Mendukung pengembangan aplikasi web dan halaman server.

Keuntungan PL / SQL

PL / SQL memiliki keuntungan sebagai berikut -

  • SQL adalah bahasa database standar dan PL / SQL sangat terintegrasi dengan SQL. PL / SQL mendukung SQL statis dan dinamis. SQL statis mendukung operasi DML dan kontrol transaksi dari blok PL / SQL. Dalam Dynamic SQL, SQL memungkinkan penyematan pernyataan DDL di blok PL / SQL.

  • PL / SQL memungkinkan pengiriman seluruh blok pernyataan ke database pada satu waktu. Ini mengurangi lalu lintas jaringan dan memberikan kinerja tinggi untuk aplikasi.

  • PL / SQL memberikan produktivitas tinggi kepada programmer karena dapat melakukan kueri, mengubah, dan memperbarui data dalam database.

  • PL / SQL menghemat waktu dalam desain dan debugging dengan fitur-fitur yang kuat, seperti penanganan pengecualian, enkapsulasi, penyembunyian data, dan tipe data berorientasi objek.

  • Aplikasi yang ditulis dalam PL / SQL sepenuhnya portabel.

  • PL / SQL memberikan tingkat keamanan yang tinggi.

  • PL / SQL menyediakan akses ke paket SQL yang telah ditentukan sebelumnya.

  • PL / SQL menyediakan dukungan untuk Pemrograman Berorientasi Objek.

  • PL / SQL menyediakan dukungan untuk mengembangkan Aplikasi Web dan Halaman Server.

Pada bab ini, kita akan membahas Pengaturan Lingkungan PL / SQL. PL / SQL bukanlah bahasa pemrograman mandiri; itu adalah alat dalam lingkungan pemrograman Oracle.SQL* Plusadalah alat interaktif yang memungkinkan Anda mengetik pernyataan SQL dan PL / SQL pada prompt perintah. Perintah-perintah ini kemudian dikirim ke database untuk diproses. Setelah pernyataan diproses, hasilnya dikirim kembali dan ditampilkan di layar.

Untuk menjalankan program PL / SQL, Anda harus menginstal Oracle RDBMS Server di mesin Anda. Ini akan menangani eksekusi perintah SQL. Versi terbaru dari Oracle RDBMS adalah 11g. Anda dapat mengunduh versi uji coba Oracle 11g dari tautan berikut -

Unduh Oracle 11g Express Edition

Anda harus mengunduh instalasi versi 32-bit atau 64-bit sesuai sistem operasi Anda. Biasanya ada dua file. Kami telah mengunduh versi 64-bit. Anda juga akan menggunakan langkah-langkah serupa pada sistem operasi Anda, tidak masalah apakah itu Linux atau Solaris.

  • win64_11gR2_database_1of2.zip

  • win64_11gR2_database_2of2.zip

Setelah mengunduh dua file di atas, Anda perlu mengekstraknya dalam satu direktori database dan di bawahnya Anda akan menemukan sub-direktori berikut -

Langkah 1

Sekarang mari kita luncurkan Penginstal Database Oracle menggunakan file setup. Berikut adalah layar pertama. Anda dapat memberikan ID email Anda dan mencentang kotak seperti yang ditunjukkan pada gambar layar berikut. KlikNext tombol.

Langkah 2

Anda akan diarahkan ke layar berikut; hapus centang pada kotak centang dan klikContinue tombol untuk melanjutkan.

LANGKAH 3

Cukup pilih opsi pertama Create and Configure Database menggunakan tombol radio dan klik Next tombol untuk melanjutkan.

LANGKAH 4

Kami berasumsi bahwa Anda menginstal Oracle untuk tujuan dasar pembelajaran dan Anda menginstalnya di PC atau Laptop Anda. Jadi, pilih fileDesktop Class opsi dan klik Next tombol untuk melanjutkan.

LANGKAH 5

Berikan lokasi, di mana Anda akan menginstal Oracle Server. Ubah sajaOracle Basedan lokasi lain akan disetel secara otomatis. Anda juga harus memberikan kata sandi; ini akan digunakan oleh sistem DBA. Setelah Anda memberikan informasi yang diperlukan, klikNext tombol untuk melanjutkan.

LANGKAH 6

Sekali lagi, klik Next tombol untuk melanjutkan.

LANGKAH 7

Klik Finishtombol untuk melanjutkan; ini akan memulai penginstalan server yang sebenarnya.

LANGKAH 8

Ini akan memakan waktu beberapa saat, hingga Oracle mulai melakukan konfigurasi yang diperlukan.

LANGKAH 9

Di sini, instalasi Oracle akan menyalin file konfigurasi yang diperlukan. Ini akan memakan waktu beberapa saat -

LANGKAH 10

Setelah file database disalin, Anda akan melihat kotak dialog berikut. Cukup klikOK tombol dan keluar.

LANGKAH 11

Setelah instalasi, Anda akan melihat jendela terakhir berikut.

Langkah terakhir

Sekarang saatnya untuk memverifikasi instalasi Anda. Pada prompt perintah, gunakan perintah berikut jika Anda menggunakan Windows -

sqlplus "/ as sysdba"

Anda harus memiliki prompt SQL di mana Anda akan menulis perintah dan skrip PL / SQL Anda -

Editor Teks

Menjalankan program besar dari command prompt dapat membuat Anda kehilangan sebagian pekerjaan secara tidak sengaja. Itu selalu disarankan untuk menggunakan file perintah. Untuk menggunakan file perintah -

  • Ketikkan kode Anda di editor teks, seperti Notepad, Notepad+, atau EditPlus, dll.

  • Simpan file dengan .sql ekstensi di direktori home.

  • Luncurkan SQL*Plus command prompt dari direktori tempat Anda membuat file PL / SQL.

  • Tipe @file_name di prompt perintah SQL * Plus untuk menjalankan program Anda.

Jika Anda tidak menggunakan file untuk mengeksekusi skrip PL / SQL, cukup salin kode PL / SQL Anda dan klik kanan pada jendela hitam yang menampilkan prompt SQL; menggunakanpasteopsi untuk menempelkan kode lengkap pada prompt perintah. Terakhir, tekan sajaEnter untuk mengeksekusi kode, jika belum dijalankan.

Pada bab ini kita akan membahas tentang Sintaks Dasar PL / SQL yaitu a block-structuredbahasa; ini berarti bahwa program PL / SQL dibagi dan ditulis dalam blok kode logis. Setiap blok terdiri dari tiga sub-bagian -

S.No Bagian & Deskripsi
1

Declarations

Bagian ini dimulai dengan kata kunci DECLARE. Ini adalah bagian opsional dan mendefinisikan semua variabel, kursor, subprogram, dan elemen lain yang akan digunakan dalam program.

2

Executable Commands

Bagian ini tertutup di antara kata kunci BEGIN dan ENDdan itu adalah bagian wajib. Ini terdiri dari pernyataan PL / SQL yang dapat dieksekusi dari program. Ini harus memiliki setidaknya satu baris kode yang dapat dieksekusi, yang mungkin hanya aNULL command untuk menunjukkan bahwa tidak ada yang harus dieksekusi.

3

Exception Handling

Bagian ini dimulai dengan kata kunci EXCEPTION. Bagian opsional ini berisiexception(s) yang menangani kesalahan dalam program.

Setiap pernyataan PL / SQL diakhiri dengan titik koma (;). Blok PL / SQL dapat disarangkan di dalam blok PL / SQL lain menggunakanBEGIN dan END. Berikut adalah struktur dasar blok PL / SQL -

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)>
EXCEPTION 
   <exception handling> 
END;

Contoh 'Hello World'

DECLARE 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/

Itu end;garis menandakan akhir dari blok PL / SQL. Untuk menjalankan kode dari baris perintah SQL, Anda mungkin perlu mengetik / di awal baris kosong pertama setelah baris terakhir kode. Ketika kode di atas dijalankan pada prompt SQL, itu menghasilkan hasil sebagai berikut -

Hello World  

PL/SQL procedure successfully completed.

Pengenal PL / SQL

Pengenal PL / SQL adalah konstanta, variabel, pengecualian, prosedur, kursor, dan kata yang dicadangkan. Pengidentifikasi terdiri dari huruf yang secara opsional diikuti dengan lebih banyak huruf, angka, tanda dolar, garis bawah, dan tanda angka dan tidak boleh melebihi 30 karakter.

Secara default, identifiers are not case-sensitive. Jadi Anda bisa menggunakaninteger atau INTEGERuntuk mewakili nilai numerik. Anda tidak dapat menggunakan kata kunci yang dipesan sebagai pengenal.

Pembatas PL / SQL

Pembatas adalah simbol dengan arti khusus. Berikut adalah daftar pembatas di PL / SQL -

Pembatas Deskripsi
+, -, *, / Penjumlahan, pengurangan / negasi, perkalian, pembagian
% Indikator atribut
' Pembatas string karakter
. Pemilih komponen
(,) Pembatas ekspresi atau daftar
: Indikator variabel host
, Pemisah item
" Pembatas pengenal yang dikutip
= Operator relasional
@ Indikator akses jarak jauh
; Terminator pernyataan
:= Operator penugasan
=> Operator asosiasi
|| Operator penggabungan
** Operator eksponen
<<, >> Pembatas label (awal dan akhir)
/*, */ Pembatas komentar banyak baris (awal dan akhir)
-- Indikator komentar satu baris
.. Operator jangkauan
<, >, <=, >= Operator relasional
<>, '=, ~=, ^= Versi yang berbeda dari TIDAK SAMA

Komentar PL / SQL

Komentar program adalah pernyataan penjelasan yang dapat dimasukkan dalam kode PL / SQL yang Anda tulis dan membantu siapa pun membaca kode sumbernya. Semua bahasa pemrograman memungkinkan beberapa bentuk komentar.

PL / SQL mendukung komentar satu baris dan banyak baris. Semua karakter yang tersedia di dalam komentar apa pun diabaikan oleh kompiler PL / SQL. Komentar baris tunggal PL / SQL dimulai dengan pemisah - (tanda hubung ganda) dan komentar multi-baris diapit oleh / * dan * /.

DECLARE 
   -- variable declaration 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   /* 
   *  PL/SQL executable statement(s) 
   */ 
   dbms_output.put_line(message); 
END; 
/

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

Hello World

PL/SQL procedure successfully completed.

Unit Program PL / SQL

Unit PL / SQL adalah salah satu dari berikut -

  • Blok PL / SQL
  • Function
  • Package
  • Isi paket
  • Procedure
  • Trigger
  • Type
  • Ketik tubuh

Masing-masing unit ini akan dibahas dalam bab-bab berikut.

Pada bab ini, kita akan membahas Tipe Data di PL / SQL. Variabel PL / SQL, konstanta, dan parameter harus memiliki tipe data yang valid, yang menentukan format penyimpanan, batasan, dan rentang nilai yang valid. Kami akan fokus padaSCALAR dan LOBtipe data dalam bab ini. Dua tipe data lainnya akan dibahas di bab lain.

S.No Kategori & Deskripsi
1

Scalar

Nilai tunggal tanpa komponen internal, seperti a NUMBER, DATE, atau BOOLEAN.

2

Large Object (LOB)

Penunjuk ke objek besar yang disimpan secara terpisah dari item data lainnya, seperti teks, gambar grafik, klip video, dan bentuk gelombang suara.

3

Composite

Item data yang memiliki komponen internal yang dapat diakses secara individual. Misalnya koleksi dan catatan.

4

Reference

Pointer ke item data lainnya.

Tipe dan Subtipe Data Skalar PL / SQL

Tipe dan Subtipe Data Skalar PL / SQL berada di bawah kategori berikut -

S.No Jenis Tanggal & Deskripsi
1

Numeric

Nilai numerik yang digunakan untuk menjalankan operasi aritmatika.

2

Character

Nilai alfanumerik yang mewakili karakter tunggal atau rangkaian karakter.

3

Boolean

Nilai logis di mana operasi logis dilakukan.

4

Datetime

Tanggal dan waktu.

PL / SQL menyediakan subtipe tipe data. Misalnya, tipe data NOMOR memiliki subtipe yang disebut INTEGER. Anda dapat menggunakan subtipe dalam program PL / SQL Anda untuk membuat tipe data kompatibel dengan tipe data di program lain sambil menyematkan kode PL / SQL di program lain, seperti program Java.

Jenis dan Subtipe Data Numerik PL / SQL

Tabel berikut mencantumkan tipe data numerik yang telah ditentukan sebelumnya PL / SQL dan sub-tipe mereka -

S.No Tipe & Deskripsi Data
1

PLS_INTEGER

Bilangan bulat yang ditandatangani dalam kisaran -2.147.483.648 hingga 2.147.483.647, direpresentasikan dalam 32 bit

2

BINARY_INTEGER

Bilangan bulat yang ditandatangani dalam kisaran -2.147.483.648 hingga 2.147.483.647, direpresentasikan dalam 32 bit

3

BINARY_FLOAT

Bilangan floating-point format IEEE 754 presisi tunggal

4

BINARY_DOUBLE

Bilangan floating-point format IEEE 754 presisi ganda

5

NUMBER(prec, scale)

Bilangan fixed-point atau floating-point dengan nilai absolut dalam rentang 1E-130 hingga (tetapi tidak termasuk) 1.0E126. Variabel NOMOR juga dapat mewakili 0

6

DEC(prec, scale)

Jenis titik tetap khusus ANSI dengan presisi maksimum 38 digit desimal

7

DECIMAL(prec, scale)

Jenis titik tetap khusus IBM dengan presisi maksimum 38 digit desimal

8

NUMERIC(pre, secale)

Tipe mengambang dengan presisi maksimum 38 digit desimal

9

DOUBLE PRECISION

Jenis floating-point khusus ANSI dengan presisi maksimum 126 digit biner (sekitar 38 digit desimal)

10

FLOAT

Jenis floating-point khusus ANSI dan IBM dengan presisi maksimum 126 digit biner (sekitar 38 digit desimal)

11

INT

Jenis integer khusus ANSI dengan presisi maksimum 38 digit desimal

12

INTEGER

Jenis integer spesifik ANSI dan IBM dengan presisi maksimum 38 digit desimal

13

SMALLINT

Jenis integer spesifik ANSI dan IBM dengan presisi maksimum 38 digit desimal

14

REAL

Tipe floating-point dengan presisi maksimum 63 digit biner (sekitar 18 digit desimal)

Berikut ini adalah pernyataan yang valid -

DECLARE 
   num1 INTEGER; 
   num2 REAL; 
   num3 DOUBLE PRECISION; 
BEGIN 
   null; 
END; 
/

Ketika kode di atas dikompilasi dan dijalankan, itu menghasilkan hasil sebagai berikut -

PL/SQL procedure successfully completed

Tipe dan Subtipe Data Karakter PL / SQL

Berikut ini adalah detail tipe data karakter yang telah ditentukan sebelumnya PL / SQL dan sub-tipe mereka -

S.No Tipe & Deskripsi Data
1

CHAR

String karakter dengan panjang tetap dengan ukuran maksimum 32.767 byte

2

VARCHAR2

String karakter dengan panjang variabel dengan ukuran maksimum 32.767 byte

3

RAW

Panjang variabel biner atau string byte dengan ukuran maksimum 32.767 byte, tidak diinterpretasikan oleh PL / SQL

4

NCHAR

String karakter nasional dengan panjang tetap dengan ukuran maksimum 32.767 byte

5

NVARCHAR2

String karakter nasional dengan panjang variabel dengan ukuran maksimum 32.767 byte

6

LONG

String karakter dengan panjang variabel dengan ukuran maksimum 32.760 byte

7

LONG RAW

Panjang variabel biner atau string byte dengan ukuran maksimum 32.760 byte, tidak diinterpretasikan oleh PL / SQL

8

ROWID

Pengenal baris fisik, alamat baris dalam tabel biasa

9

UROWID

Pengenal baris universal (pengenal baris fisik, logis, atau asing)

Tipe Data PL / SQL Boolean

Itu BOOLEANtipe data menyimpan nilai logika yang digunakan dalam operasi logika. Nilai logika adalah nilai BooleanTRUE dan FALSE dan nilainya NULL.

Namun, SQL tidak memiliki tipe data yang setara dengan BOOLEAN. Oleh karena itu, nilai Boolean tidak dapat digunakan di -

  • Pernyataan SQL
  • Fungsi SQL bawaan (seperti TO_CHAR)
  • Fungsi PL / SQL dipanggil dari pernyataan SQL

PL / SQL Datetime dan Jenis Interval

Itu DATEdatatype digunakan untuk menyimpan waktu tetap, yang mencakup waktu dalam hitungan detik sejak tengah malam. Tanggal yang valid berkisar dari 1 Januari 4712 SM hingga 31 Desember 9999 M.

Format tanggal default ditetapkan oleh parameter inisialisasi Oracle NLS_DATE_FORMAT. Misalnya, defaultnya mungkin 'DD-MON-YY', yang menyertakan angka dua digit untuk hari dalam sebulan, singkatan dari nama bulan, dan dua digit terakhir tahun ini. Misalnya, 01-OCT-12.

Setiap DATE menyertakan abad, tahun, bulan, hari, jam, menit, dan detik. Tabel berikut menunjukkan nilai yang valid untuk setiap bidang -

Nama Bidang Nilai Tanggal Waktu yang Valid Nilai Interval yang Valid
TAHUN -4712 hingga 9999 (tidak termasuk tahun 0) Semua bilangan bulat bukan nol
BULAN 01 sampai 12 0 sampai 11
HARI 01 hingga 31 (dibatasi oleh nilai MONTH dan YEAR, sesuai dengan aturan kalender untuk lokal) Semua bilangan bulat bukan nol
JAM 00 sampai 23 0 sampai 23
MENIT 00 sampai 59 0 hingga 59
KEDUA 00 hingga 59,9 (n), di mana 9 (n) adalah ketepatan waktu pecahan detik 0 hingga 59,9 (n), di mana 9 (n) adalah ketepatan dari detik pecahan interval
TIMEZONE_HOUR -12 hingga 14 (kisaran mengakomodasi perubahan waktu musim panas) Tak dapat diterapkan
TIMEZONE_MINUTE 00 sampai 59 Tak dapat diterapkan
TIMEZONE_REGION Ditemukan dalam tampilan kinerja dinamis V $ TIMEZONE_NAMES Tak dapat diterapkan
TIMEZONE_ABBR Ditemukan dalam tampilan kinerja dinamis V $ TIMEZONE_NAMES Tak dapat diterapkan

Tipe Data PL / SQL Large Object (LOB)

Tipe data Objek Besar (LOB) mengacu pada item data besar seperti teks, gambar grafik, klip video, dan bentuk gelombang suara. Tipe data LOB memungkinkan akses yang efisien, acak, sedikit demi sedikit ke data ini. Berikut adalah tipe data PL / SQL LOB yang telah ditentukan -

Tipe data Deskripsi Ukuran
BFILE Digunakan untuk menyimpan objek biner besar dalam file sistem operasi di luar database. Tergantung sistem. Tidak boleh melebihi 4 gigabyte (GB).
GUMPAL Digunakan untuk menyimpan objek biner besar dalam database. 8 hingga 128 terabyte (TB)
CLOB Digunakan untuk menyimpan blok besar data karakter dalam database. 8 hingga 128 TB
NCLOB Digunakan untuk menyimpan blok besar data NCHAR dalam database. 8 hingga 128 TB

PL / SQL yang Ditentukan Pengguna Subtipe

Subtipe adalah himpunan bagian dari tipe data lain, yang disebut tipe dasarnya. Subtipe memiliki operasi valid yang sama dengan tipe dasarnya, tetapi hanya sebagian dari nilai validnya.

PL / SQL telah mendefinisikan beberapa subtipe dalam paket STANDARD. Misalnya, PL / SQL telah mendefinisikan subtipeCHARACTER dan INTEGER sebagai berikut -

SUBTYPE CHARACTER IS CHAR; 
SUBTYPE INTEGER IS NUMBER(38,0);

Anda dapat menentukan dan menggunakan subtipe Anda sendiri. Program berikut mengilustrasikan mendefinisikan dan menggunakan subtipe yang ditentukan pengguna -

DECLARE 
   SUBTYPE name IS char(20); 
   SUBTYPE message IS varchar2(100); 
   salutation name; 
   greetings message; 
BEGIN 
   salutation := 'Reader '; 
   greetings := 'Welcome to the World of PL/SQL'; 
   dbms_output.put_line('Hello ' || salutation || greetings); 
END; 
/

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

Hello Reader Welcome to the World of PL/SQL 
 
PL/SQL procedure successfully completed.

NULL di PL / SQL

Nilai PL / SQL NULL mewakili missing atau unknown datadan mereka bukan integer, karakter, atau tipe data spesifik lainnya. Catat ituNULL tidak sama dengan string data kosong atau nilai karakter null '\0'. Nol dapat ditetapkan tetapi tidak dapat disamakan dengan apa pun, termasuk dirinya sendiri.

Pada bab ini, kita akan membahas Variabel dalam Pl / SQL. Variabel tidak lain adalah nama yang diberikan ke area penyimpanan yang dapat dimanipulasi oleh program kami. Setiap variabel dalam PL / SQL memiliki tipe data tertentu, yang menentukan ukuran dan tata letak memori variabel; kisaran nilai yang dapat disimpan di dalam memori itu dan rangkaian operasi yang dapat diterapkan ke variabel.

Nama variabel PL / SQL terdiri dari huruf yang secara opsional diikuti dengan lebih banyak huruf, angka, tanda dolar, garis bawah, dan tanda angka dan tidak boleh melebihi 30 karakter. Secara default, nama variabel tidak peka huruf besar kecil. Anda tidak dapat menggunakan kata kunci PL / SQL yang dicadangkan sebagai nama variabel.

Bahasa pemrograman PL / SQL memungkinkan untuk mendefinisikan berbagai jenis variabel, seperti jenis data waktu tanggal, catatan, koleksi, dll. Yang akan kita bahas pada bab-bab selanjutnya. Untuk bab ini, mari kita pelajari hanya tipe variabel dasar.

Deklarasi Variabel di PL / SQL

Variabel PL / SQL harus dideklarasikan di bagian deklarasi atau dalam paket sebagai variabel global. Saat Anda mendeklarasikan variabel, PL / SQL mengalokasikan memori untuk nilai variabel dan lokasi penyimpanan diidentifikasi dengan nama variabel.

Sintaks untuk mendeklarasikan variabel adalah -

variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]

Di mana, nama_variabel adalah pengidentifikasi yang valid di PL / SQL, tipe data harus merupakan tipe data PL / SQL yang valid atau tipe data yang ditentukan pengguna yang telah kita bahas di bab terakhir. Beberapa deklarasi variabel yang valid beserta definisinya ditunjukkan di bawah ini -

sales number(10, 2); 
pi CONSTANT double precision := 3.1415; 
name varchar2(25); 
address varchar2(100);

Saat Anda memberikan ukuran, skala, atau batas presisi dengan tipe data, itu disebut a constrained declaration. Deklarasi terbatas membutuhkan lebih sedikit memori daripada deklarasi tidak terbatas. Misalnya -

sales number(10, 2); 
name varchar2(25); 
address varchar2(100);

Menginisialisasi Variabel dalam PL / SQL

Setiap kali Anda mendeklarasikan variabel, PL / SQL memberikannya nilai default NULL. Jika Anda ingin menginisialisasi variabel dengan nilai selain nilai NULL, Anda dapat melakukannya selama deklarasi, menggunakan salah satu dari berikut -

  • Itu DEFAULT kata kunci

  • Itu assignment operator

Misalnya -

counter binary_integer := 0; 
greetings varchar2(20) DEFAULT 'Have a Good Day';

Anda juga dapat menentukan bahwa variabel tidak boleh memiliki NULL nilai menggunakan NOT NULLpaksaan. Jika Anda menggunakan batasan NOT NULL, Anda harus secara eksplisit menetapkan nilai awal untuk variabel itu.

Ini adalah praktik pemrograman yang baik untuk menginisialisasi variabel dengan benar jika tidak, terkadang program akan menghasilkan hasil yang tidak terduga. Coba contoh berikut yang menggunakan berbagai jenis variabel -

DECLARE 
   a integer := 10; 
   b integer := 20; 
   c integer; 
   f real; 
BEGIN 
   c := a + b; 
   dbms_output.put_line('Value of c: ' || c); 
   f := 70.0/3.0; 
   dbms_output.put_line('Value of f: ' || f); 
END; 
/

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

Value of c: 30 
Value of f: 23.333333333333333333  

PL/SQL procedure successfully completed.

Variable Scope di PL / SQL

PL / SQL memungkinkan penumpukan blok, yaitu, setiap blok program dapat berisi blok dalam lainnya. Jika variabel dideklarasikan di dalam blok dalam, itu tidak dapat diakses ke blok luar. Namun, jika variabel dideklarasikan dan dapat diakses oleh blok luar, itu juga dapat diakses oleh semua blok dalam bersarang. Ada dua jenis ruang lingkup variabel -

  • Local variables - Variabel dideklarasikan dalam blok dalam dan tidak dapat diakses oleh blok luar.

  • Global variables - Variabel dideklarasikan di blok terluar atau paket.

Contoh berikut menunjukkan penggunaan Local dan Global variabel dalam bentuk sederhananya -

DECLARE 
   -- Global variables  
   num1 number := 95;  
   num2 number := 85;  
BEGIN  
   dbms_output.put_line('Outer Variable num1: ' || num1); 
   dbms_output.put_line('Outer Variable num2: ' || num2); 
   DECLARE  
      -- Local variables 
      num1 number := 195;  
      num2 number := 185;  
   BEGIN  
      dbms_output.put_line('Inner Variable num1: ' || num1); 
      dbms_output.put_line('Inner Variable num2: ' || num2); 
   END;  
END; 
/

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

Outer Variable num1: 95 
Outer Variable num2: 85 
Inner Variable num1: 195 
Inner Variable num2: 185  

PL/SQL procedure successfully completed.

Menetapkan Hasil Query SQL ke Variabel PL / SQL

Anda bisa menggunakan SELECT INTOpernyataan SQL untuk memberikan nilai ke variabel PL / SQL. Untuk setiap item diSELECT list, harus ada variabel yang sesuai dan kompatibel dengan jenis di INTO list. Contoh berikut menggambarkan konsep tersebut. Mari kita buat tabel bernama CUSTOMERS -

(For SQL statements, please refer to the SQL tutorial)

CREATE TABLE CUSTOMERS( 
   ID   INT NOT NULL, 
   NAME VARCHAR (20) NOT NULL, 
   AGE INT NOT NULL, 
   ADDRESS CHAR (25), 
   SALARY   DECIMAL (18, 2),        
   PRIMARY KEY (ID) 
);  

Table Created

Sekarang mari kita masukkan beberapa nilai ke dalam tabel -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
  
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 
 
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 );

Program berikut memberikan nilai dari tabel di atas ke variabel PL / SQL menggunakan SELECT INTO clause dari SQL -

DECLARE 
   c_id customers.id%type := 1; 
   c_name  customers.name%type; 
   c_addr customers.address%type; 
   c_sal  customers.salary%type; 
BEGIN 
   SELECT name, address, salary INTO c_name, c_addr, c_sal 
   FROM customers 
   WHERE id = c_id;  
   dbms_output.put_line 
   ('Customer ' ||c_name || ' from ' || c_addr || ' earns ' || c_sal); 
END; 
/

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

Customer Ramesh from Ahmedabad earns 2000  

PL/SQL procedure completed successfully

Pada bab ini, kita akan membahasnya constants dan literalsdi PL / SQL. Sebuah konstanta memiliki nilai yang setelah dideklarasikan, tidak berubah dalam program. Deklarasi konstan menentukan nama, tipe data, dan nilainya, dan mengalokasikan penyimpanan untuknya. Deklarasi tersebut juga dapat memberlakukanNOT NULL constraint.

Mendeklarasikan Konstanta

Sebuah konstanta dideklarasikan menggunakan CONSTANTkata kunci. Ini membutuhkan nilai awal dan tidak mengizinkan nilai itu diubah. Misalnya -

PI CONSTANT NUMBER := 3.141592654; 
DECLARE 
   -- constant declaration 
   pi constant number := 3.141592654; 
   -- other declarations 
   radius number(5,2);  
   dia number(5,2);  
   circumference number(7, 2); 
   area number (10, 2); 
BEGIN  
   -- processing 
   radius := 9.5;  
   dia := radius * 2;  
   circumference := 2.0 * pi * radius; 
   area := pi * radius * radius; 
   -- output 
   dbms_output.put_line('Radius: ' || radius); 
   dbms_output.put_line('Diameter: ' || dia); 
   dbms_output.put_line('Circumference: ' || circumference); 
   dbms_output.put_line('Area: ' || area); 
END; 
/

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

Radius: 9.5 
Diameter: 19 
Circumference: 59.69 
Area: 283.53  

Pl/SQL procedure successfully completed.

Literal PL / SQL

Literal adalah nilai numerik, karakter, string, atau Boolean eksplisit yang tidak diwakili oleh pengenal. Misalnya, TRUE, 786, NULL, 'tutorialspoint' adalah semua literal jenis Boolean, angka, atau string. PL / SQL, literal peka huruf besar kecil. PL / SQL mendukung jenis literal berikut -

  • Literal Numerik
  • Karakter Literal
  • String Literals
  • BOOLEAN Literals
  • Tanggal dan Waktu Literals

Tabel berikut memberikan contoh dari semua kategori nilai literal ini.

S.No Jenis & Contoh Literal
1

Numeric Literals

050 78-14 0 +32767

6.6667 0.0 -12.0 3.14159 +7800.00

6E5 1.0E-8 3.14159e0 -1E38 -9.5e-3

2

Character Literals

'A' '%' '9' '' 'z' '('

3

String Literals

'Halo Dunia!'

'Tutorial Poin'

'19 -NOV-12 '

4

BOOLEAN Literals

TRUE, FALSE, dan NULL.

5

Date and Time Literals

DATE '1978-12-25';

TIMESTAMP '2012-10-29 12:01:01';

Untuk menyematkan tanda kutip tunggal dalam string literal, tempatkan dua tanda kutip tunggal di samping satu sama lain seperti yang ditunjukkan dalam program berikut -

DECLARE 
   message  varchar2(30):= 'That''s tutorialspoint.com!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/

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

That's tutorialspoint.com!  

PL/SQL procedure successfully completed.

Pada bab ini, kita akan membahas operator dalam PL / SQL. Operator adalah simbol yang memberi tahu kompiler untuk melakukan manipulasi matematika atau logika tertentu. Bahasa PL / SQL kaya akan operator bawaan dan menyediakan jenis operator berikut -

  • Operator aritmatika
  • Operator relasional
  • Operator perbandingan
  • Operator logika
  • Operator string

Di sini, kita akan memahami operator aritmatika, relasional, perbandingan, dan logika satu per satu. Operator String akan dibahas di bab selanjutnya -PL/SQL - Strings.

Operator Aritmatika

Tabel berikut menunjukkan semua operator aritmatika yang didukung oleh PL / SQL. Mari kita asumsikanvariable A memegang 10 dan variable B memegang 5, lalu -

Tunjukkan Contoh

Operator Deskripsi Contoh
+ Menambahkan dua operan A + B akan menghasilkan 15
- Mengurangi operan kedua dari yang pertama A - B akan memberikan 5
* Menggandakan kedua operan A * B akan memberi 50
/ Membagi pembilang dengan de-numerator A / B akan memberi 2
** Operator eksponen, menaikkan satu operan ke pangkat lainnya A ** B akan memberikan 100000

Operator Relasional

Operator relasional membandingkan dua ekspresi atau nilai dan mengembalikan hasil Boolean. Tabel berikut menunjukkan semua operator relasional yang didukung oleh PL / SQL. Mari kita asumsikanvariable A memegang 10 dan variable B memegang 20, lalu -

Tunjukkan Contoh

Operator Deskripsi Contoh
= Memeriksa apakah nilai dari dua operan sama atau tidak, jika ya maka kondisinya menjadi benar. (A = B) tidak benar.

! =

<>

~ =

Memeriksa apakah nilai dari dua operan sama atau tidak, jika nilai tidak sama maka kondisi menjadi benar. (A! = B) benar.
> Memeriksa apakah nilai operan kiri lebih besar dari nilai operan kanan, jika ya maka kondisi menjadi benar. (A> B) tidak benar.
< Memeriksa apakah nilai operan kiri kurang dari nilai operan kanan, jika ya maka kondisinya menjadi benar. (A <B) benar.
> = Memeriksa apakah nilai operan kiri lebih besar dari atau sama dengan nilai operan kanan, jika ya maka kondisi menjadi benar. (A> = B) tidak benar.
<= Memeriksa apakah nilai operan kiri kurang dari atau sama dengan nilai operan kanan, jika ya maka kondisi menjadi benar. (A <= B) benar

Operator Perbandingan

Operator perbandingan digunakan untuk membandingkan satu ekspresi dengan ekspresi lainnya. Hasilnya selalu baikTRUE, FALSE atau NULL.

Tunjukkan Contoh

Operator Deskripsi Contoh
SUKA Operator LIKE membandingkan karakter, string, atau nilai CLOB ke pola dan mengembalikan TRUE jika nilainya cocok dengan pola dan FALSE jika tidak. Jika 'Zara Ali' seperti 'Z% A_i' mengembalikan Boolean benar, sedangkan 'Nuha Ali' seperti 'Z% A_i' mengembalikan Boolean salah.
ANTARA Operator BETWEEN menguji apakah suatu nilai berada dalam kisaran tertentu. x ANTARA a DAN b berarti x> = a dan x <= b. Jika x = 10 lalu, x antara 5 dan 20 mengembalikan benar, x antara 5 dan 10 mengembalikan benar, tetapi x antara 11 dan 20 mengembalikan salah.
DI Tes operator IN mengatur keanggotaan. x IN (set) berarti x sama dengan anggota himpunan manapun. Jika x = 'm' lalu, x in ('a', 'b', 'c') mengembalikan Boolean false tetapi x in ('m', 'n', 'o') mengembalikan Boolean true.
IS NULL Operator IS NULL mengembalikan nilai BOOLEAN TRUE jika operannya adalah NULL atau FALSE jika bukan NULL. Perbandingan yang melibatkan nilai NULL selalu menghasilkan NULL. Jika x = 'm', maka 'x is null' mengembalikan Boolean false.

Operator Logis

Tabel berikut menunjukkan operator Logika yang didukung oleh PL / SQL. Semua operator ini bekerja pada operan Boolean dan menghasilkan hasil Boolean. Mari kita asumsikanvariable A berlaku dan variable B memegang salah, lalu -

Tunjukkan Contoh

Operator Deskripsi Contoh
dan Disebut operator logika AND. Jika kedua operan benar maka kondisi menjadi benar. (A dan B) salah.
atau Disebut Operator OR logis. Jika salah satu dari dua operan benar maka kondisi menjadi benar. (A atau B) benar.
tidak Disebut Operator NOT logis. Digunakan untuk membalikkan keadaan logis operannya. Jika kondisi benar maka operator NOT akan membuatnya salah. tidak (A dan B) benar.

Diutamakan Operator PL / SQL

Prioritas operator menentukan pengelompokan istilah dalam ekspresi. Ini memengaruhi bagaimana ekspresi dievaluasi. Operator tertentu memiliki prioritas lebih tinggi daripada yang lain; Misalnya, operator perkalian memiliki prioritas lebih tinggi daripada operator penjumlahan.

Sebagai contoh, x = 7 + 3 * 2; sini,x ditugaskan 13, bukan 20 karena operator * lebih diutamakan daripada +, jadi operator * akan dikalikan terlebih dahulu 3*2 dan kemudian menambahkan ke 7.

Di sini, operator dengan prioritas tertinggi muncul di bagian atas tabel, operator dengan prioritas terendah muncul di bagian bawah. Dalam ekspresi, operator dengan prioritas lebih tinggi akan dievaluasi terlebih dahulu.

Prioritas operator berjalan sebagai berikut: =, <,>, <=,> =, <>,! =, ~ =, ^ =, IS NULL, LIKE, BETWEEN, IN.

Tunjukkan Contoh

Operator Operasi
** eksponensial
+, - identitas, negasi
*, / perkalian, pembagian
+, -, || penjumlahan, pengurangan, penggabungan
perbandingan
TIDAK negasi logis
DAN konjungsi
ATAU penyertaan

Pada bab ini, kita akan membahas kondisi dalam PL / SQL. Struktur pengambilan keputusan mengharuskan programmer menentukan satu atau lebih kondisi yang akan dievaluasi atau diuji oleh program, bersama dengan pernyataan atau pernyataan yang akan dieksekusi jika kondisi ditentukan benar, dan secara opsional, pernyataan lain akan dieksekusi jika kondisi ditentukan sebagai salah.

Berikut ini adalah bentuk umum dari struktur bersyarat (yaitu, pengambilan keputusan) yang ditemukan di sebagian besar bahasa pemrograman -

Bahasa pemrograman PL / SQL menyediakan jenis pernyataan pengambilan keputusan berikut. Klik tautan berikut untuk memeriksa detailnya.

S.No Pernyataan & Deskripsi
1 JIKA - MAKA pernyataan

Itu IF statement mengaitkan kondisi dengan urutan pernyataan yang diapit oleh kata kunci THEN dan END IF. Jika kondisinya benar, pernyataan dieksekusi dan jika kondisinya salah atau NULL maka pernyataan IF tidak melakukan apa-apa.

2 Pernyataan IF-THEN-ELSE

IF statement menambahkan kata kunci ELSEdiikuti oleh urutan pernyataan alternatif. Jika kondisinya salah atau NULL, maka hanya urutan alternatif pernyataan yang dieksekusi. Ini memastikan bahwa salah satu dari urutan pernyataan dieksekusi.

3 Pernyataan IF-THEN-ELSIF

Ini memungkinkan Anda untuk memilih di antara beberapa alternatif.

4 Pernyataan kasus

Seperti pernyataan IF, CASE statement memilih satu urutan pernyataan untuk dieksekusi.

Namun, untuk memilih urutan, pernyataan CASE menggunakan selektor daripada beberapa ekspresi Boolean. Selektor adalah ekspresi yang nilainya digunakan untuk memilih salah satu dari beberapa alternatif.

5 Pernyataan CASE ditelusuri

Pernyataan CASE yang dicari has no selector, dan klausa WHEN berisi kondisi pencarian yang menghasilkan nilai Boolean.

6 bertumpuk IF-THEN-ELSE

Anda bisa menggunakannya IF-THEN atau IF-THEN-ELSIF pernyataan di dalam yang lain IF-THEN atau IF-THEN-ELSIF pernyataan.

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 di 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 ruang lingkup, semua objek otomatis yang dibuat dalam lingkup itu 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 melewatkan sisa tubuhnya dan segera menguji ulang kondisinya sebelum mengulangi.

3 Pernyataan GOTO

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

String dalam PL / SQL sebenarnya adalah urutan karakter dengan spesifikasi ukuran opsional. Karakter bisa berupa angka, huruf, kosong, karakter khusus atau kombinasi semuanya. PL / SQL menawarkan tiga jenis string -

  • Fixed-length strings- Dalam string seperti itu, programmer menentukan panjangnya saat mendeklarasikan string. Stringnya empuk kanan dengan spasi dengan panjang yang ditentukan.

  • Variable-length strings - Dalam string tersebut, panjang maksimum hingga 32.767, untuk string ditentukan dan tidak ada bantalan yang terjadi.

  • Character large objects (CLOBs) - Ini adalah string dengan panjang variabel yang bisa mencapai 128 terabyte.

String PL / SQL dapat berupa variabel atau literal. Literal string diapit dalam tanda kutip. Sebagai contoh,

'This is a string literal.' Or 'hello world'

Untuk menyertakan satu kutipan di dalam string literal, Anda perlu mengetikkan dua tanda kutip tunggal di samping satu sama lain. Sebagai contoh,

'this isn''t what it looks like'

Mendeklarasikan Variabel String

Database Oracle menyediakan banyak tipe data string, seperti CHAR, NCHAR, VARCHAR2, NVARCHAR2, CLOB, dan NCLOB. Tipe data yang diawali dengan'N' adalah 'national character set' datatypes, yang menyimpan data karakter Unicode.

Jika Anda perlu mendeklarasikan string dengan panjang variabel, Anda harus memberikan panjang maksimum string tersebut. Misalnya, tipe data VARCHAR2. Contoh berikut mengilustrasikan mendeklarasikan dan menggunakan beberapa variabel string -

DECLARE 
   name varchar2(20); 
   company varchar2(30); 
   introduction clob; 
   choice char(1); 
BEGIN 
   name := 'John Smith'; 
   company := 'Infotech'; 
   introduction := ' Hello! I''m John Smith from Infotech.'; 
   choice := 'y'; 
   IF choice = 'y' THEN 
      dbms_output.put_line(name); 
      dbms_output.put_line(company); 
      dbms_output.put_line(introduction); 
   END IF; 
END; 
/

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

John Smith 
Infotech
Hello! I'm John Smith from Infotech.  

PL/SQL procedure successfully completed

Untuk mendeklarasikan string panjang tetap, gunakan tipe data CHAR. Di sini Anda tidak perlu menentukan panjang maksimum untuk variabel panjang tetap. Jika Anda membiarkan batasan panjang, Oracle Database secara otomatis menggunakan panjang maksimum yang diperlukan. Dua pernyataan berikut ini identik -

red_flag CHAR(1) := 'Y'; 
 red_flag CHAR   := 'Y';

Fungsi dan Operator String PL / SQL

PL / SQL menawarkan operator penggabungan (||)untuk menggabungkan dua string. Tabel berikut menyediakan fungsi string yang disediakan oleh PL / SQL -

S.No Fungsi & Tujuan
1

ASCII(x);

Mengembalikan nilai ASCII dari karakter x.

2

CHR(x);

Mengembalikan karakter dengan nilai ASCII x.

3

CONCAT(x, y);

Menggabungkan string x dan y dan mengembalikan string yang ditambahkan.

4

INITCAP(x);

Mengonversi huruf awal dari setiap kata dalam x menjadi huruf besar dan mengembalikan string itu.

5

INSTR(x, find_string [, start] [, occurrence]);

Pencarian untuk find_string di x dan mengembalikan posisi terjadinya.

6

INSTRB(x);

Mengembalikan lokasi string dalam string lain, tetapi mengembalikan nilai dalam byte.

7

LENGTH(x);

Mengembalikan jumlah karakter dalam x.

8

LENGTHB(x);

Mengembalikan panjang string karakter dalam byte untuk kumpulan karakter byte tunggal.

9

LOWER(x);

Mengonversi huruf dalam x menjadi huruf kecil dan mengembalikan string itu.

10

LPAD(x, width [, pad_string]) ;

Bantalan x dengan spasi di sebelah kiri, untuk menambah panjang total string menjadi karakter lebar.

11

LTRIM(x [, trim_string]);

Memangkas karakter dari kiri x.

12

NANVL(x, value);

Mengembalikan nilai jika x cocok dengan nilai khusus NaN (bukan angka), jika tidak x dikembalikan.

13

NLS_INITCAP(x);

Sama seperti fungsi INITCAP, kecuali fungsi tersebut dapat menggunakan metode pengurutan yang berbeda seperti yang ditentukan oleh NLSSORT.

14

NLS_LOWER(x) ;

Sama seperti fungsi LOWER kecuali bahwa itu dapat menggunakan metode pengurutan yang berbeda seperti yang ditentukan oleh NLSSORT.

15

NLS_UPPER(x);

Sama seperti fungsi UPPER, kecuali fungsi tersebut dapat menggunakan metode pengurutan yang berbeda seperti yang ditentukan oleh NLSSORT.

16

NLSSORT(x);

Mengubah metode pengurutan karakter. Harus ditentukan sebelum fungsi NLS; jika tidak, pengurutan default akan digunakan.

17

NVL(x, value);

Mengembalikan nilai jika xadalah nol; jika tidak, x dikembalikan.

18

NVL2(x, value1, value2);

Mengembalikan nilai1 jika x bukan nol; jika x adalah nol, nilai2 dikembalikan.

19

REPLACE(x, search_string, replace_string);

Pencarian x untuk search_string dan menggantinya dengan replace_string.

20

RPAD(x, width [, pad_string]);

Bantalan x ke kanan.

21

RTRIM(x [, trim_string]);

Trims x dari kanan.

22

SOUNDEX(x) ;

Mengembalikan string yang berisi representasi fonetik dari x.

23

SUBSTR(x, start [, length]);

Menampilkan substring dari xyang dimulai pada posisi yang ditentukan oleh start. Panjang opsional untuk substring mungkin diberikan.

24

SUBSTRB(x);

Sama seperti SUBSTR kecuali bahwa parameternya dinyatakan dalam byte, bukan karakter untuk sistem karakter byte tunggal.

25

TRIM([trim_char FROM) x);

Memangkas karakter dari kiri dan kanan x.

26

UPPER(x);

Mengonversi huruf dalam x menjadi huruf besar dan mengembalikan string itu.

Sekarang mari kita mengerjakan beberapa contoh untuk memahami konsep -

Contoh 1

DECLARE 
   greetings varchar2(11) := 'hello world'; 
BEGIN 
   dbms_output.put_line(UPPER(greetings)); 
    
   dbms_output.put_line(LOWER(greetings)); 
    
   dbms_output.put_line(INITCAP(greetings)); 
    
   /* retrieve the first character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, 1, 1)); 
    
   /* retrieve the last character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, -1, 1)); 
    
   /* retrieve five characters,  
      starting from the seventh position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 7, 5)); 
    
   /* retrieve the remainder of the string, 
      starting from the second position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 2)); 
     
   /* find the location of the first "e" */ 
   dbms_output.put_line ( INSTR (greetings, 'e')); 
END; 
/

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

HELLO WORLD 
hello world 
Hello World 
h 
d 
World 
ello World 
2  

PL/SQL procedure successfully completed.

Contoh 2

DECLARE 
   greetings varchar2(30) := '......Hello World.....'; 
BEGIN 
   dbms_output.put_line(RTRIM(greetings,'.')); 
   dbms_output.put_line(LTRIM(greetings, '.')); 
   dbms_output.put_line(TRIM( '.' from greetings)); 
END; 
/

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

......Hello World  
Hello World..... 
Hello World  

PL/SQL procedure successfully completed.

Pada bab ini, kita akan membahas array dalam PL / SQL. Bahasa pemrograman PL / SQL menyediakan struktur data yang disebutVARRAY, yang dapat menyimpan kumpulan elemen berurutan ukuran tetap dari jenis yang sama. Sebuah varray digunakan untuk menyimpan kumpulan data yang terurut, namun seringkali lebih baik untuk menganggap sebuah array sebagai kumpulan variabel dari tipe yang sama.

Semua varray terdiri dari lokasi memori yang berdekatan. Alamat terendah sesuai dengan elemen pertama dan alamat tertinggi untuk elemen terakhir.

Array adalah bagian dari data tipe koleksi dan itu singkatan dari array ukuran variabel. Kami akan mempelajari jenis koleksi lainnya di bab selanjutnya'PL/SQL Collections'.

Setiap elemen di a varraymemiliki indeks yang terkait dengannya. Ini juga memiliki ukuran maksimum yang dapat diubah secara dinamis.

Membuat Jenis Varray

Jenis varray dibuat dengan CREATE TYPEpernyataan. Anda harus menentukan ukuran maksimum dan jenis elemen yang disimpan di varray.

Sintaks dasar untuk membuat tipe VARRAY di level skema adalah -

CREATE OR REPLACE TYPE varray_type_name IS VARRAY(n) of <element_type>

Dimana,

  • varray_type_name adalah nama atribut yang valid,
  • n adalah jumlah elemen (maksimum) di varray,
  • element_type adalah tipe data dari elemen array.

Ukuran maksimum varray dapat diubah menggunakan ALTER TYPE pernyataan.

Sebagai contoh,

CREATE Or REPLACE TYPE namearray AS VARRAY(3) OF VARCHAR2(10); 
/ 

Type created.

Sintaks dasar untuk membuat tipe VARRAY dalam blok PL / SQL adalah -

TYPE varray_type_name IS VARRAY(n) of <element_type>

Misalnya -

TYPE namearray IS VARRAY(5) OF VARCHAR2(10); 
Type grades IS VARRAY(5) OF INTEGER;

Sekarang mari kita mengerjakan beberapa contoh untuk memahami konsep -

Contoh 1

Program berikut menggambarkan penggunaan varrays -

DECLARE 
   type namesarray IS VARRAY(5) OF VARCHAR2(10); 
   type grades IS VARRAY(5) OF INTEGER; 
   names namesarray; 
   marks grades; 
   total integer; 
BEGIN 
   names := namesarray('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.

Please note -

  • Di lingkungan Oracle, indeks awal untuk varray selalu 1.

  • Anda dapat menginisialisasi elemen varray menggunakan metode konstruktor dari jenis varray, yang memiliki nama yang sama dengan varray.

  • Varray adalah array satu dimensi.

  • Sebuah varray secara otomatis NULL ketika dideklarasikan dan harus diinisialisasi sebelum elemennya dapat direferensikan.

Contoh 2

Elemen varray juga bisa berupa% ROWTYPE dari tabel database atau% TYPE dari kolom 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 | 
+----+----------+-----+-----------+----------+

Contoh berikut memanfaatkan cursor, yang akan Anda pelajari secara mendetail di bab terpisah.

DECLARE 
   CURSOR c_customers is 
   SELECT  name FROM customers; 
   type c_list is varray (6) of customers.name%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.

Pada bab ini, kita akan membahas Prosedur dalam PL / SQL. SEBUAHsubprogramadalah unit / modul program yang menjalankan tugas tertentu. Subprogram ini digabungkan untuk membentuk program yang lebih besar. Ini pada dasarnya disebut 'desain Modular'. Sebuah subprogram dapat dipanggil oleh subprogram atau program lain yang disebutcalling program.

Sebuah subprogram dapat dibuat -

  • Di level skema
  • Di dalam sebuah paket
  • Di dalam blok PL / SQL

Pada level skema, subprogram adalah a standalone subprogram. Itu dibuat dengan pernyataan CREATE PROCEDURE atau CREATE FUNCTION. Itu disimpan dalam database dan dapat dihapus dengan pernyataan DROP PROCEDURE atau DROP FUNCTION.

Subprogram yang dibuat di dalam paket adalah packaged subprogram. Itu disimpan dalam database dan hanya dapat dihapus ketika paket dihapus dengan pernyataan DROP PACKAGE. Kami akan membahas paket di bab ini'PL/SQL - Packages'.

Subprogram PL / SQL diberi nama blok PL / SQL yang dapat dipanggil dengan sekumpulan parameter. PL / SQL menyediakan dua jenis subprogram -

  • Functions- Subprogram ini mengembalikan satu nilai; terutama digunakan untuk menghitung dan mengembalikan nilai.

  • Procedures- Subprogram ini tidak mengembalikan nilai secara langsung; terutama digunakan untuk melakukan suatu tindakan.

Bab ini akan membahas aspek-aspek penting dari a PL/SQL procedure. Kami akan membahasPL/SQL function di bab selanjutnya.

Bagian dari Subprogram PL / SQL

Setiap subprogram PL / SQL memiliki nama, dan mungkin juga memiliki daftar parameter. Seperti blok PL / SQL anonim, blok bernama juga akan memiliki tiga bagian berikut -

S.No Bagian & Deskripsi
1

Declarative Part

Ini adalah bagian opsional. Namun, bagian deklaratif untuk subprogram tidak dimulai dengan kata kunci MENYATAKAN. Ini berisi deklarasi tipe, kursor, konstanta, variabel, pengecualian, dan subprogram bertingkat. Item ini bersifat lokal untuk subprogram dan tidak ada lagi saat subprogram menyelesaikan eksekusi.

2

Executable Part

Ini adalah bagian wajib dan berisi pernyataan yang melakukan tindakan yang ditentukan.

3

Exception-handling

Ini lagi-lagi merupakan bagian opsional. Ini berisi kode yang menangani kesalahan run-time.

Membuat Prosedur

Sebuah prosedur dibuat dengan CREATE OR REPLACE PROCEDUREpernyataan. Sintaks yang disederhanakan untuk pernyataan CREATE OR REPLACE PROCEDURE adalah sebagai berikut -

CREATE [OR REPLACE] PROCEDURE procedure_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
{IS | AS} 
BEGIN 
  < procedure_body > 
END procedure_name;

Dimana,

  • procedure-name menentukan nama prosedur.

  • Opsi [ATAU GANTI] memungkinkan modifikasi dari prosedur yang ada.

  • Daftar parameter opsional berisi nama, mode, dan jenis parameter. IN mewakili nilai yang akan diteruskan dari luar dan KELUAR mewakili parameter yang akan digunakan untuk mengembalikan nilai di luar prosedur.

  • procedure-body berisi bagian yang dapat dieksekusi.

  • Kata kunci AS digunakan sebagai pengganti kata kunci IS untuk membuat prosedur mandiri.

Contoh

Contoh berikut membuat prosedur sederhana yang menampilkan string 'Hello World!' di layar saat dijalankan.

CREATE OR REPLACE PROCEDURE greetings 
AS 
BEGIN 
   dbms_output.put_line('Hello World!'); 
END; 
/

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

Procedure created.

Menjalankan Prosedur Mandiri

Prosedur mandiri dapat dilakukan dengan dua cara -

  • Menggunakan EXECUTE kata kunci

  • Memanggil nama prosedur dari blok PL / SQL

Prosedur di atas bernama 'greetings' dapat disebut dengan kata kunci LAKUKAN sebagai -

EXECUTE greetings;

Panggilan di atas akan menampilkan -

Hello World

PL/SQL procedure successfully completed.

Prosedurnya juga dapat dipanggil dari blok PL / SQL lain -

BEGIN 
   greetings; 
END; 
/

Panggilan di atas akan menampilkan -

Hello World  

PL/SQL procedure successfully completed.

Menghapus Prosedur Mandiri

Prosedur mandiri dihapus dengan DROP PROCEDUREpernyataan. Sintaks untuk menghapus prosedur adalah -

DROP PROCEDURE procedure-name;

Anda dapat membatalkan prosedur salam dengan menggunakan pernyataan berikut -

DROP PROCEDURE greetings;

Mode Parameter dalam Subprogram PL / SQL

Tabel berikut mencantumkan mode parameter dalam subprogram PL / SQL -

S.No Mode & Deskripsi Parameter
1

IN

Parameter IN memungkinkan Anda memberikan nilai ke subprogram. It is a read-only parameter. Di dalam subprogram, parameter IN bertindak seperti konstanta. Itu tidak dapat diberi nilai. Anda dapat mengirimkan konstanta, literal, variabel yang diinisialisasi, atau ekspresi sebagai parameter IN. Anda juga dapat menginisialisasinya ke nilai default; namun, dalam kasus itu, itu dihilangkan dari panggilan subprogram.It is the default mode of parameter passing. Parameters are passed by reference.

2

OUT

Parameter OUT mengembalikan nilai ke program pemanggil. Di dalam subprogram, parameter OUT bertindak seperti variabel. Anda dapat mengubah nilainya dan mereferensikan nilai setelah menetapkannya.The actual parameter must be variable and it is passed by value.

3

IN OUT

Sebuah IN OUTparameter meneruskan nilai awal ke subprogram dan mengembalikan nilai yang diperbarui ke pemanggil. Itu bisa diberi nilai dan nilainya bisa dibaca.

Parameter aktual yang sesuai dengan parameter formal IN OUT harus berupa variabel, bukan konstanta atau ekspresi. Parameter formal harus diberi nilai.Actual parameter is passed by value.

Contoh Mode Masuk & Keluar 1

Program ini menemukan minimal dua nilai. Di sini, prosedur mengambil dua angka menggunakan mode IN dan mengembalikan nilai minimumnya menggunakan parameter OUT.

DECLARE 
   a number; 
   b number; 
   c number;
PROCEDURE findMin(x IN number, y IN number, z OUT number) IS 
BEGIN 
   IF x < y THEN 
      z:= x; 
   ELSE 
      z:= y; 
   END IF; 
END;   
BEGIN 
   a:= 23; 
   b:= 45; 
   findMin(a, b, c); 
   dbms_output.put_line(' Minimum of (23, 45) : ' || c); 
END; 
/

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

Minimum of (23, 45) : 23  

PL/SQL procedure successfully completed.

Contoh Mode Masuk & Keluar 2

Prosedur ini menghitung kuadrat nilai dari nilai yang diteruskan. Contoh ini menunjukkan bagaimana kita dapat menggunakan parameter yang sama untuk menerima nilai dan kemudian mengembalikan hasil lain.

DECLARE 
   a number; 
PROCEDURE squareNum(x IN OUT number) IS 
BEGIN 
  x := x * x; 
END;  
BEGIN 
   a:= 23; 
   squareNum(a); 
   dbms_output.put_line(' Square of (23): ' || a); 
END; 
/

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

Square of (23): 529 

PL/SQL procedure successfully completed.

Metode untuk Meneruskan Parameter

Parameter aktual dapat dilewatkan dalam tiga cara -

  • Notasi posisi
  • Notasi bernama
  • Notasi campuran

Notasi Posisi

Dalam notasi posisi, Anda dapat memanggil prosedur sebagai -

findMin(a, b, c, d);

Dalam notasi posisi, parameter aktual pertama diganti dengan parameter formal pertama; parameter aktual kedua diganti dengan parameter formal kedua, dan seterusnya. Begitu,a diganti x, b diganti y, c diganti z dan d diganti m.

Notasi Bernama

Dalam notasi bernama, parameter aktual dikaitkan dengan parameter formal menggunakan arrow symbol ( => ). Panggilan prosedur akan seperti berikut -

findMin(x => a, y => b, z => c, m => d);

Notasi Campuran

Dalam notasi campuran, Anda dapat mencampur kedua notasi dalam pemanggilan prosedur; namun, notasi posisional harus mendahului notasi bernama.

Panggilan berikut ini sah -

findMin(a, b, c, m => d);

Namun, ini tidak legal:

findMin(x => a, b, c, d);

Pada bab ini, kita akan membahas fungsi-fungsi dalam PL / SQL. Suatu fungsi sama dengan prosedur kecuali ia mengembalikan nilai. Oleh karena itu, semua pembahasan pada bab sebelumnya juga berlaku untuk fungsi.

Membuat Fungsi

Fungsi mandiri dibuat menggunakan CREATE FUNCTIONpernyataan. Sintaks yang disederhanakan untuk fileCREATE OR REPLACE PROCEDURE pernyataannya adalah sebagai berikut -

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

Dimana,

  • function-name menentukan nama fungsinya.

  • Opsi [ATAU GANTI] memungkinkan modifikasi fungsi yang sudah ada.

  • Daftar parameter opsional berisi nama, mode, dan jenis parameter. IN mewakili nilai yang akan diteruskan dari luar dan OUT mewakili parameter yang akan digunakan untuk mengembalikan nilai di luar prosedur.

  • Fungsi tersebut harus mengandung a return pernyataan.

  • The RETURN klausul menentukan jenis data yang Anda akan kembali dari fungsi.

  • function-body berisi bagian yang dapat dieksekusi.

  • Kata kunci AS digunakan sebagai pengganti kata kunci IS untuk membuat fungsi mandiri.

Contoh

Contoh berikut mengilustrasikan cara membuat dan memanggil fungsi mandiri. Fungsi ini mengembalikan jumlah PELANGGAN di tabel pelanggan.

Kami akan menggunakan tabel CUSTOMERS, yang telah kami buat di bab Variabel PL / SQL -

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 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

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

Function created.

Memanggil Fungsi

Saat membuat fungsi, Anda memberikan definisi tentang apa yang harus dilakukan fungsi tersebut. Untuk menggunakan suatu fungsi, Anda harus memanggil fungsi itu untuk melakukan tugas yang ditentukan. Ketika program memanggil suatu fungsi, kontrol program dipindahkan ke fungsi yang dipanggil.

Fungsi yang dipanggil melakukan tugas yang ditentukan dan kapan pernyataan kembaliannya dijalankan atau saat last end statement tercapai, ia mengembalikan kontrol program ke program utama.

Untuk memanggil suatu fungsi, Anda hanya perlu meneruskan parameter yang diperlukan bersama dengan nama fungsi dan jika fungsi mengembalikan nilai, Anda dapat menyimpan nilai yang dikembalikan. Program berikut memanggil fungsi tersebuttotalCustomers dari blok anonim -

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

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

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

Contoh

Contoh berikut menunjukkan Mendeklarasikan, Mendefinisikan, dan Memanggil Fungsi PL / SQL Sederhana yang menghitung dan mengembalikan maksimal dua nilai.

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

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

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

Fungsi Rekursif PL / SQL

Kita telah melihat bahwa suatu program atau subprogram dapat memanggil subprogram lain. Ketika sebuah subprogram memanggil dirinya sendiri, itu disebut sebagai panggilan rekursif dan prosesnya dikenal sebagairecursion.

Untuk mengilustrasikan konsep tersebut, mari kita menghitung faktorial sebuah bilangan. Faktorial bilangan n didefinisikan sebagai -

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

Program berikut menghitung faktorial dari bilangan tertentu dengan memanggil dirinya sendiri secara rekursif -

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

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

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.

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

Dalam bab ini, kita akan membahas Records di PL / SQL. SEBUAHrecordadalah struktur data yang dapat menampung item data dari berbagai jenis. Rekaman terdiri dari bidang yang berbeda, mirip dengan baris tabel database.

Misalnya, Anda ingin melacak buku Anda di perpustakaan. Anda mungkin ingin melacak atribut berikut tentang setiap buku, seperti Judul, Penulis, Subjek, ID Buku. Catatan yang berisi bidang untuk masing-masing item ini memungkinkan memperlakukan BUKU sebagai unit logis dan memungkinkan Anda untuk mengatur dan merepresentasikan informasinya dengan cara yang lebih baik.

PL / SQL dapat menangani jenis record berikut -

  • Table-based
  • Catatan berbasis kursor
  • Catatan yang ditentukan pengguna

Catatan Berbasis Tabel

Atribut% ROWTYPE memungkinkan programmer untuk membuat table-based dan cursorbased catatan.

Contoh berikut menggambarkan konsep table-basedcatatan. Kami akan menggunakan tabel CUSTOMERS yang telah kami buat dan gunakan di bab sebelumnya -

DECLARE 
   customer_rec customers%rowtype; 
BEGIN 
   SELECT * into customer_rec 
   FROM customers 
   WHERE id = 5;  
   dbms_output.put_line('Customer ID: ' || customer_rec.id); 
   dbms_output.put_line('Customer Name: ' || customer_rec.name); 
   dbms_output.put_line('Customer Address: ' || customer_rec.address); 
   dbms_output.put_line('Customer Salary: ' || customer_rec.salary); 
END; 
/

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

Customer ID: 5 
Customer Name: Hardik 
Customer Address: Bhopal 
Customer Salary: 9000 
 
PL/SQL procedure successfully completed.

Catatan Berbasis Kursor

Contoh berikut menggambarkan konsep cursor-basedcatatan. Kami akan menggunakan tabel CUSTOMERS yang telah kami buat dan gunakan di bab sebelumnya -

DECLARE 
   CURSOR customer_cur is 
      SELECT id, name, address  
      FROM customers; 
   customer_rec customer_cur%rowtype; 
BEGIN 
   OPEN customer_cur; 
   LOOP 
      FETCH customer_cur into customer_rec; 
      EXIT WHEN customer_cur%notfound; 
      DBMS_OUTPUT.put_line(customer_rec.id || ' ' || customer_rec.name); 
   END LOOP; 
END; 
/

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

1 Ramesh 
2 Khilan 
3 kaushik 
4 Chaitali 
5 Hardik 
6 Komal  

PL/SQL procedure successfully completed.

Record Buatan Pengguna

PL / SQL menyediakan tipe record yang ditentukan pengguna yang memungkinkan Anda untuk menentukan struktur record yang berbeda. Catatan ini terdiri dari bidang yang berbeda. Misalkan Anda ingin melacak buku Anda di perpustakaan. Anda mungkin ingin melacak atribut berikut tentang setiap buku -

  • Title
  • Author
  • Subject
  • ID Buku

Mendefinisikan Record

Jenis rekaman didefinisikan sebagai -

TYPE 
type_name IS RECORD 
  ( field_name1  datatype1  [NOT NULL]  [:= DEFAULT EXPRESSION], 
   field_name2   datatype2   [NOT NULL]  [:= DEFAULT EXPRESSION], 
   ... 
   field_nameN  datatypeN  [NOT NULL]  [:= DEFAULT EXPRESSION); 
record-name  type_name;

Catatan Buku dideklarasikan dengan cara berikut -

DECLARE 
TYPE books IS RECORD 
(title  varchar(50), 
   author  varchar(50), 
   subject varchar(100), 
   book_id   number); 
book1 books; 
book2 books;

Mengakses Bidang

Untuk mengakses bidang catatan apa pun, kami menggunakan titik (.)operator. Operator akses anggota dikodekan sebagai periode antara nama variabel record dan field yang ingin kita akses. Berikut adalah contoh untuk menjelaskan penggunaan record -

DECLARE 
   type books is record 
      (title varchar(50), 
      author varchar(50), 
      subject varchar(100), 
      book_id number); 
   book1 books; 
   book2 books; 
BEGIN 
   -- Book 1 specification 
   book1.title  := 'C Programming'; 
   book1.author := 'Nuha Ali ';  
   book1.subject := 'C Programming Tutorial'; 
   book1.book_id := 6495407;  
   -- Book 2 specification 
   book2.title := 'Telecom Billing'; 
   book2.author := 'Zara Ali'; 
   book2.subject := 'Telecom Billing Tutorial'; 
   book2.book_id := 6495700;  
  
  -- Print book 1 record 
   dbms_output.put_line('Book 1 title : '|| book1.title); 
   dbms_output.put_line('Book 1 author : '|| book1.author); 
   dbms_output.put_line('Book 1 subject : '|| book1.subject); 
   dbms_output.put_line('Book 1 book_id : ' || book1.book_id); 
   
   -- Print book 2 record 
   dbms_output.put_line('Book 2 title : '|| book2.title); 
   dbms_output.put_line('Book 2 author : '|| book2.author); 
   dbms_output.put_line('Book 2 subject : '|| book2.subject); 
   dbms_output.put_line('Book 2 book_id : '|| book2.book_id); 
END; 
/

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

Book 1 title : C Programming 
Book 1 author : Nuha Ali 
Book 1 subject : C Programming Tutorial 
Book 1 book_id : 6495407 
Book 2 title : Telecom Billing 
Book 2 author : Zara Ali 
Book 2 subject : Telecom Billing Tutorial 
Book 2 book_id : 6495700  

PL/SQL procedure successfully completed.

Rekaman sebagai Parameter Subprogram

Anda dapat mengirimkan record sebagai parameter subprogram seperti halnya Anda mengirimkan variabel lainnya. Anda juga dapat mengakses kolom record dengan cara yang sama seperti yang Anda akses pada contoh di atas -

DECLARE 
   type books is record 
      (title  varchar(50), 
      author  varchar(50), 
      subject varchar(100), 
      book_id   number); 
   book1 books; 
   book2 books;  
PROCEDURE printbook (book books) IS 
BEGIN 
   dbms_output.put_line ('Book  title :  ' || book.title); 
   dbms_output.put_line('Book  author : ' || book.author); 
   dbms_output.put_line( 'Book  subject : ' || book.subject); 
   dbms_output.put_line( 'Book book_id : ' || book.book_id); 
END; 
   
BEGIN 
   -- Book 1 specification 
   book1.title  := 'C Programming'; 
   book1.author := 'Nuha Ali ';  
   book1.subject := 'C Programming Tutorial'; 
   book1.book_id := 6495407;
   
   -- Book 2 specification 
   book2.title := 'Telecom Billing'; 
   book2.author := 'Zara Ali'; 
   book2.subject := 'Telecom Billing Tutorial'; 
   book2.book_id := 6495700;  
   
   -- Use procedure to print book info 
   printbook(book1); 
   printbook(book2); 
END; 
/

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

Book  title : C Programming 
Book  author : Nuha Ali 
Book subject : C Programming Tutorial 
Book  book_id : 6495407 
Book title : Telecom Billing 
Book author : Zara Ali 
Book subject : Telecom Billing Tutorial 
Book book_id : 6495700  

PL/SQL procedure successfully completed.

Pada bab ini, kita akan membahas Pengecualian di PL / SQL. Pengecualian adalah kondisi kesalahan selama eksekusi program. PL / SQL mendukung pemrogram untuk menangkap kondisi seperti itu menggunakanEXCEPTIONblokir dalam program dan tindakan yang tepat diambil terhadap kondisi kesalahan. Ada dua jenis pengecualian -

  • Pengecualian yang ditentukan sistem
  • Pengecualian yang ditentukan pengguna

Sintaks untuk Penanganan Pengecualian

Sintaks umum untuk penanganan pengecualian adalah sebagai berikut. Di sini Anda dapat membuat daftar pengecualian sebanyak yang Anda bisa tangani. Pengecualian default akan ditangani menggunakanWHEN others THEN -

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)> 
EXCEPTION 
   <exception handling goes here > 
   WHEN exception1 THEN  
      exception1-handling-statements  
   WHEN exception2  THEN  
      exception2-handling-statements  
   WHEN exception3 THEN  
      exception3-handling-statements 
   ........ 
   WHEN others THEN 
      exception3-handling-statements 
END;

Contoh

Mari kita tulis kode untuk menggambarkan konsep tersebut. Kami akan menggunakan tabel CUSTOMERS yang telah kami buat dan gunakan di bab sebelumnya -

DECLARE 
   c_id customers.id%type := 8; 
   c_name customerS.Name%type; 
   c_addr customers.address%type; 
BEGIN 
   SELECT  name, address INTO  c_name, c_addr 
   FROM customers 
   WHERE id = c_id;  
   DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name); 
   DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 

EXCEPTION 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!'); 
END; 
/

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

No such customer!  

PL/SQL procedure successfully completed.

Program di atas menampilkan nama dan alamat pelanggan yang ID-nya diberikan. Karena tidak ada pelanggan dengan nilai ID 8 di database kami, program memunculkan pengecualian waktu prosesNO_DATA_FOUND, yang ditangkap di EXCEPTION block.

Meningkatkan Pengecualian

Pengecualian dimunculkan oleh server basis data secara otomatis setiap kali ada kesalahan basis data internal, tetapi pengecualian dapat dimunculkan secara eksplisit oleh pemrogram dengan menggunakan perintah RAISE. Berikut ini adalah sintaks sederhana untuk memunculkan pengecualian -

DECLARE 
   exception_name EXCEPTION; 
BEGIN 
   IF condition THEN 
      RAISE exception_name; 
   END IF; 
EXCEPTION 
   WHEN exception_name THEN 
   statement; 
END;

Anda dapat menggunakan sintaks di atas untuk meningkatkan pengecualian standar Oracle atau pengecualian yang ditentukan pengguna. Di bagian selanjutnya, kami akan memberi Anda contoh tentang memunculkan pengecualian yang ditentukan pengguna. Anda dapat meningkatkan pengecualian standar Oracle dengan cara yang serupa.

Pengecualian Buatan Pengguna

PL / SQL memungkinkan Anda untuk menentukan pengecualian Anda sendiri sesuai dengan kebutuhan program Anda. Pengecualian yang ditentukan pengguna harus dideklarasikan dan kemudian dimunculkan secara eksplisit, baik menggunakan pernyataan RAISE atau prosedurDBMS_STANDARD.RAISE_APPLICATION_ERROR.

Sintaks untuk mendeklarasikan pengecualian adalah -

DECLARE 
   my-exception EXCEPTION;

Contoh

Contoh berikut menggambarkan konsep tersebut. Program ini meminta ID pelanggan, ketika pengguna memasukkan ID yang tidak valid, pengecualianinvalid_id dibesarkan.

DECLARE 
   c_id customers.id%type := &cc_id; 
   c_name customerS.Name%type; 
   c_addr customers.address%type;  
   -- user defined exception 
   ex_invalid_id  EXCEPTION; 
BEGIN 
   IF c_id <= 0 THEN 
      RAISE ex_invalid_id; 
   ELSE 
      SELECT  name, address INTO  c_name, c_addr 
      FROM customers 
      WHERE id = c_id;
      DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name);  
      DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 
   END IF; 

EXCEPTION 
   WHEN ex_invalid_id THEN 
      dbms_output.put_line('ID must be greater than zero!'); 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!');  
END; 
/

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

Enter value for cc_id: -6 (let's enter a value -6) 
old  2: c_id customers.id%type := &cc_id; 
new  2: c_id customers.id%type := -6; 
ID must be greater than zero! 
 
PL/SQL procedure successfully completed.

Pengecualian yang Ditentukan Sebelumnya

PL / SQL menyediakan banyak pengecualian yang telah ditentukan sebelumnya, yang dijalankan ketika ada aturan database yang dilanggar oleh program. Misalnya, pengecualian NO_DATA_FOUND yang telah ditentukan dimunculkan ketika pernyataan SELECT INTO tidak mengembalikan baris. Tabel berikut mencantumkan beberapa pengecualian penting yang telah ditentukan sebelumnya -

Pengecualian Kesalahan Oracle SQLCODE Deskripsi
ACCESS_INTO_NULL 06530 -6530 Dibesarkan ketika objek null secara otomatis diberi nilai.
CASE_NOT_FOUND 06592 -6592 Dibesarkan jika tidak ada pilihan dalam klausa WHEN dari pernyataan CASE yang dipilih, dan tidak ada klausa ELSE.
COLLECTION_IS_NULL 06531 -6531 Dibesarkan ketika program mencoba menerapkan metode pengumpulan selain EXISTS ke tabel atau varray bersarang yang tidak diinisialisasi, atau program mencoba untuk menetapkan nilai ke elemen tabel atau varray bersarang yang tidak diinisialisasi.
DUP_VAL_ON_INDEX 00001 -1 Dibesarkan saat nilai duplikat berusaha disimpan dalam kolom dengan indeks unik.
INVALID_CURSOR 01001 -1001 Dibesarkan ketika upaya dilakukan untuk membuat operasi kursor yang tidak diperbolehkan, seperti menutup kursor yang belum dibuka.
INVALID_NUMBER 01722 -1722 Dibesarkan ketika konversi string karakter menjadi angka gagal karena string tidak mewakili angka yang valid.
LOGIN_DENIED 01017 -1017 Dibesarkan ketika program mencoba masuk ke database dengan nama pengguna atau kata sandi yang tidak valid.
TIDAK ADA DATA DITEMUKAN 01403 +100 Dibesarkan ketika pernyataan SELECT INTO tidak mengembalikan baris.
NOT_LOGGED_ON 01012 -1012 Dibesarkan ketika panggilan database dikeluarkan tanpa terhubung ke database.
PROGRAM_ERROR 06501 -6501 Dibesarkan ketika PL / SQL memiliki masalah internal.
ROWTYPE_MISMATCH 06504 -6504 Dibesarkan saat kursor mengambil nilai dalam variabel yang memiliki tipe data yang tidak kompatibel.
SELF_IS_NULL 30625 -30625 Itu dimunculkan ketika metode anggota dipanggil, tetapi contoh tipe objek tidak diinisialisasi.
STORAGE_ERROR 06500 -6500 Dibesarkan ketika PL / SQL kehabisan memori atau memori rusak.
TOO_MANY_ROWS 01422 -1422 Dibesarkan ketika pernyataan SELECT INTO mengembalikan lebih dari satu baris.
VALUE_ERROR 06502 -6502 Dibesarkan ketika terjadi kesalahan aritmatika, konversi, pemotongan, atau batasan ukuran.
ZERO_DIVIDE 01476 1476 Dibesarkan saat percobaan dilakukan untuk membagi angka dengan nol.

Pada bab ini, kita akan membahas Pemicu di PL / SQL. Pemicu adalah program yang disimpan, yang dijalankan atau dijalankan secara otomatis ketika beberapa peristiwa terjadi. Faktanya, pemicu ditulis untuk dieksekusi sebagai respons terhadap salah satu peristiwa berikut -

  • SEBUAH database manipulation (DML) pernyataan (DELETE, INSERT, atau UPDATE)

  • SEBUAH database definition (DDL) pernyataan (CREATE, ALTER, atau DROP).

  • SEBUAH database operation (SERVERERROR, LOGON, LOGOFF, STARTUP, atau SHUTDOWN).

Pemicu dapat ditentukan di tabel, tampilan, skema, atau database yang terkait dengan peristiwa tersebut.

Manfaat Pemicu

Pemicu dapat ditulis untuk tujuan berikut -

  • Menghasilkan beberapa nilai kolom turunan secara otomatis
  • Menerapkan integritas referensial
  • Event logging dan menyimpan informasi pada akses tabel
  • Auditing
  • Replikasi tabel secara sinkron
  • Menerapkan otorisasi keamanan
  • Mencegah transaksi tidak valid

Membuat Pemicu

Sintaks untuk membuat pemicu adalah -

CREATE [OR REPLACE ] TRIGGER trigger_name  
{BEFORE | AFTER | INSTEAD OF }  
{INSERT [OR] | UPDATE [OR] | DELETE}  
[OF col_name]  
ON table_name  
[REFERENCING OLD AS o NEW AS n]  
[FOR EACH ROW]  
WHEN (condition)   
DECLARE 
   Declaration-statements 
BEGIN  
   Executable-statements 
EXCEPTION 
   Exception-handling-statements 
END;

Dimana,

  • BUAT [ATAU GANTI] TRIGGER trigger_name - Membuat atau mengganti trigger yang ada dengan trigger_name .

  • {SEBELUM | SETELAH | INSTEAD OF} - Ini menentukan kapan pemicu akan dijalankan. Klausa INSTEAD OF digunakan untuk membuat pemicu pada tampilan.

  • {SISIPKAN [OR] | UPDATE [ATAU] | HAPUS} - Ini menentukan operasi DML.

  • [OF col_name] - Ini menentukan nama kolom yang akan diperbarui.

  • [ON table_name] - Ini menentukan nama tabel yang terkait dengan pemicu.

  • [MEREFERENSI LAMA SEBAGAI BARU AS n] - Ini memungkinkan Anda untuk merujuk nilai baru dan lama untuk berbagai pernyataan DML, seperti INSERT, UPDATE, dan DELETE.

  • [UNTUK SETIAP BARIS] - Ini menentukan pemicu tingkat baris, yaitu, pemicu akan dijalankan untuk setiap baris yang terpengaruh. Jika tidak, pemicu akan dijalankan hanya sekali saat pernyataan SQL dijalankan, yang disebut pemicu tingkat tabel.

  • WHEN (kondisi) - Ini memberikan kondisi untuk baris yang akan memicu pemicu. Klausul ini hanya berlaku untuk pemicu tingkat baris.

Contoh

Untuk memulainya, kita akan menggunakan tabel CUSTOMERS yang telah kita 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 membuat file row-levelmemicu tabel pelanggan yang akan mengaktifkan operasi INSERT atau UPDATE atau DELETE yang dilakukan pada tabel CUSTOMERS. Pemicu ini akan menampilkan perbedaan gaji antara nilai lama dan nilai baru -

CREATE OR REPLACE TRIGGER display_salary_changes 
BEFORE DELETE OR INSERT OR UPDATE ON customers 
FOR EACH ROW 
WHEN (NEW.ID > 0) 
DECLARE 
   sal_diff number; 
BEGIN 
   sal_diff := :NEW.salary  - :OLD.salary; 
   dbms_output.put_line('Old salary: ' || :OLD.salary); 
   dbms_output.put_line('New salary: ' || :NEW.salary); 
   dbms_output.put_line('Salary difference: ' || sal_diff); 
END; 
/

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

Trigger created.

Poin-poin berikut perlu dipertimbangkan di sini -

  • Referensi LAMA dan BARU tidak tersedia untuk pemicu tingkat tabel, Anda dapat menggunakannya untuk pemicu tingkat catatan.

  • Jika Anda ingin membuat kueri tabel di pemicu yang sama, Anda harus menggunakan kata kunci SETELAH, karena pemicu dapat membuat kueri tabel atau mengubahnya lagi hanya setelah perubahan awal diterapkan dan tabel kembali dalam keadaan konsisten.

  • Pemicu di atas telah ditulis sedemikian rupa sehingga akan diaktifkan sebelum operasi DELETE atau INSERT atau UPDATE apa pun pada tabel, tetapi Anda dapat menulis pemicu Anda pada satu atau beberapa operasi, misalnya SEBELUM DIHAPUS, yang akan diaktifkan setiap kali ada record akan dihapus menggunakan operasi DELETE pada tabel.

Memicu Pemicu

Mari kita lakukan beberapa operasi DML pada tabel CUSTOMERS. Berikut adalah satu pernyataan INSERT, yang akan membuat record baru di tabel -

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Kriti', 22, 'HP', 7500.00 );

Saat record dibuat di tabel CUSTOMERS, pemicu di atas membuat, display_salary_changes akan dipecat dan itu akan menampilkan hasil sebagai berikut -

Old salary: 
New salary: 7500 
Salary difference:

Karena ini adalah rekor baru, gaji lama tidak tersedia dan hasil di atas dianggap nol. Sekarang mari kita melakukan satu operasi DML lagi pada tabel PELANGGAN. Pernyataan UPDATE akan memperbarui catatan yang ada di tabel -

UPDATE customers 
SET salary = salary + 500 
WHERE id = 2;

Saat record diupdate di tabel CUSTOMERS, pemicu di atas membuat, display_salary_changes akan dipecat dan itu akan menampilkan hasil sebagai berikut -

Old salary: 1500 
New salary: 2000 
Salary difference: 500

Pada bab ini, kita akan membahas Paket-Paket di PL / SQL. Paket adalah objek skema yang mengelompokkan jenis, variabel, dan subprogram PL / SQL yang terkait secara logis.

Sebuah paket akan memiliki dua bagian wajib -

  • Spesifikasi paket
  • Isi atau definisi paket

Spesifikasi Paket

Spesifikasi adalah antarmuka ke paket. Itu hanyaDECLARESjenis, variabel, konstanta, pengecualian, kursor, dan subprogram yang dapat dirujuk dari luar paket. Dengan kata lain, ini berisi semua informasi tentang isi paket, tetapi tidak termasuk kode subprogram.

Semua objek yang ditempatkan dalam spesifikasi dipanggil publicbenda. Subprogram apa pun yang tidak ada dalam spesifikasi paket tetapi dikodekan di badan paket disebut aprivate obyek.

Cuplikan kode berikut menunjukkan spesifikasi paket yang memiliki satu prosedur. Anda dapat menentukan banyak variabel global dan beberapa prosedur atau fungsi di dalam sebuah paket.

CREATE PACKAGE cust_sal AS 
   PROCEDURE find_sal(c_id customers.id%type); 
END cust_sal; 
/

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

Package created.

Isi Paket

Badan paket memiliki kode untuk berbagai metode yang dideklarasikan dalam spesifikasi paket dan deklarasi pribadi lainnya, yang disembunyikan dari kode di luar paket.

Itu CREATE PACKAGE BODYPernyataan digunakan untuk membuat badan paket. Potongan kode berikut menunjukkan deklarasi badan paket untukcust_salpaket yang dibuat di atas. Saya berasumsi bahwa kita sudah memiliki tabel CUSTOMERS yang dibuat di database kita seperti yang disebutkan di bab PL / SQL - Variables .

CREATE OR REPLACE PACKAGE BODY cust_sal AS  
   
   PROCEDURE find_sal(c_id customers.id%TYPE) IS 
   c_sal customers.salary%TYPE; 
   BEGIN 
      SELECT salary INTO c_sal 
      FROM customers 
      WHERE id = c_id; 
      dbms_output.put_line('Salary: '|| c_sal); 
   END find_sal; 
END cust_sal; 
/

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

Package body created.

Menggunakan Elemen Paket

Elemen paket (variabel, prosedur atau fungsi) diakses dengan sintaks berikut -

package_name.element_name;

Pertimbangkan, kami telah membuat paket di atas dalam skema database kami, program berikut menggunakan find_sal metode dari cust_sal paket -

DECLARE 
   code customers.id%type := &cc_id; 
BEGIN 
   cust_sal.find_sal(code); 
END; 
/

Ketika kode di atas dijalankan pada prompt SQL, ia meminta untuk memasukkan ID pelanggan dan ketika Anda memasukkan ID, ini akan menampilkan gaji yang sesuai sebagai berikut -

Enter value for cc_id: 1 
Salary: 3000 

PL/SQL procedure successfully completed.

Contoh

Program berikut ini memberikan paket yang lebih lengkap. Kami akan menggunakan tabel PELANGGAN yang disimpan dalam database kami dengan catatan berikut -

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  3000.00 | 
|  2 | Khilan   |  25 | Delhi     |  3000.00 | 
|  3 | kaushik  |  23 | Kota      |  3000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  7500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  9500.00 | 
|  6 | Komal    |  22 | MP        |  5500.00 | 
+----+----------+-----+-----------+----------+

Spesifikasi Paket

CREATE OR REPLACE PACKAGE c_package AS 
   -- Adds a customer 
   PROCEDURE addCustomer(c_id   customers.id%type, 
   c_name  customerS.No.ame%type, 
   c_age  customers.age%type, 
   c_addr customers.address%type,  
   c_sal  customers.salary%type); 
   
   -- Removes a customer 
   PROCEDURE delCustomer(c_id  customers.id%TYPE); 
   --Lists all customers 
   PROCEDURE listCustomer; 
  
END c_package; 
/

Ketika kode di atas dijalankan pada prompt SQL, itu membuat paket di atas dan menampilkan hasil berikut -

Package created.

Membuat Badan Paket

CREATE OR REPLACE PACKAGE BODY c_package AS 
   PROCEDURE addCustomer(c_id  customers.id%type, 
      c_name customerS.No.ame%type, 
      c_age  customers.age%type, 
      c_addr  customers.address%type,  
      c_sal   customers.salary%type) 
   IS 
   BEGIN 
      INSERT INTO customers (id,name,age,address,salary) 
         VALUES(c_id, c_name, c_age, c_addr, c_sal); 
   END addCustomer; 
   
   PROCEDURE delCustomer(c_id   customers.id%type) IS 
   BEGIN 
      DELETE FROM customers 
      WHERE id = c_id; 
   END delCustomer;  
   
   PROCEDURE listCustomer IS 
   CURSOR c_customers is 
      SELECT  name FROM customers; 
   TYPE c_list is TABLE OF customers.Name%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 listCustomer;
   
END c_package; 
/

Contoh di atas memanfaatkan file nested table. Kita akan membahas konsep tabel bersarang di bab berikutnya.

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

Package body created.

Menggunakan The Package

Program berikut menggunakan metode yang dideklarasikan dan didefinisikan dalam paket c_package .

DECLARE 
   code customers.id%type:= 8; 
BEGIN 
   c_package.addcustomer(7, 'Rajnish', 25, 'Chennai', 3500); 
   c_package.addcustomer(8, 'Subham', 32, 'Delhi', 7500); 
   c_package.listcustomer; 
   c_package.delcustomer(code); 
   c_package.listcustomer; 
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 
Customer(7): Rajnish 
Customer(8): Subham 
Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal
Customer(7): Rajnish 

PL/SQL procedure successfully completed

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 tipe tabel PL / SQL, yaitu tabel index-by dan nested tables memiliki struktur yang sama dan baris-barisnya diakses dengan 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 sejumlah 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 terakhir (terbesar) dalam koleksi yang menggunakan langganan 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 dari 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 kisaran 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.

Pada bab ini, kita akan membahas transaksi di PL / SQL. Sebuah databasetransactionadalah unit kerja atom yang mungkin terdiri dari satu atau lebih pernyataan SQL terkait. Disebut atomic karena modifikasi database yang dibawa oleh pernyataan SQL yang merupakan transaksi dapat secara kolektif dilakukan, yaitu dibuat permanen ke database atau dibatalkan (dibatalkan) dari database.

Pernyataan SQL yang berhasil dijalankan dan transaksi yang dilakukan tidak sama. Bahkan jika pernyataan SQL berhasil dieksekusi, kecuali jika transaksi yang berisi pernyataan tersebut dilakukan, itu dapat dibatalkan dan semua perubahan yang dibuat oleh pernyataan tersebut dapat dibatalkan.

Memulai dan Mengakhiri Transaksi

Sebuah transaksi memiliki a beginning dan sebuah end. Transaksi dimulai ketika salah satu dari peristiwa berikut ini terjadi -

  • Pernyataan SQL pertama dilakukan setelah terhubung ke database.

  • Pada setiap pernyataan SQL baru yang dikeluarkan setelah transaksi selesai.

Transaksi berakhir ketika salah satu dari peristiwa berikut terjadi -

  • SEBUAH COMMIT atau a ROLLBACK pernyataan dikeluarkan.

  • SEBUAH DDL pernyataan, seperti CREATE TABLEpernyataan, dikeluarkan; karena dalam kasus tersebut sebuah COMMIT dilakukan secara otomatis.

  • SEBUAH DCL pernyataan, seperti a GRANTpernyataan, dikeluarkan; karena dalam kasus tersebut sebuah COMMIT dilakukan secara otomatis.

  • Pengguna terputus dari database.

  • Pengguna keluar dari SQL*PLUS dengan menerbitkan EXIT perintah, COMMIT secara otomatis dilakukan.

  • SQL * Plus berakhir secara tidak normal, a ROLLBACK dilakukan secara otomatis.

  • SEBUAH DMLpernyataan gagal; dalam hal ini ROLLBACK secara otomatis dilakukan untuk membatalkan pernyataan DML tersebut.

Melakukan Transaksi

Transaksi dibuat permanen dengan mengeluarkan perintah SQL COMMIT. Sintaks umum untuk perintah COMMIT adalah -

COMMIT;

Sebagai contoh,

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 ); 

COMMIT;

Transaksi Rolling Back

Perubahan yang dibuat ke database tanpa COMMIT dapat dibatalkan menggunakan perintah ROLLBACK.

Sintaks umum untuk perintah ROLLBACK adalah -

ROLLBACK [TO SAVEPOINT < savepoint_name>];

Ketika transaksi dibatalkan karena beberapa situasi yang belum pernah terjadi sebelumnya, seperti kegagalan sistem, seluruh transaksi sejak komit secara otomatis dibatalkan. Jika Anda tidak menggunakansavepoint, lalu cukup gunakan pernyataan berikut untuk mengembalikan semua perubahan -

ROLLBACK;

Savepoints

Savepoints adalah semacam penanda yang membantu membagi transaksi panjang menjadi unit-unit yang lebih kecil dengan menetapkan beberapa pos pemeriksaan. Dengan mengatur titik simpanan dalam transaksi panjang, Anda dapat memutar kembali ke pos pemeriksaan jika diperlukan. Ini dilakukan dengan menerbitkan fileSAVEPOINT perintah.

Sintaks umum untuk perintah SAVEPOINT adalah -

SAVEPOINT < savepoint_name >;

Sebagai contoh

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Rajnish', 27, 'HP', 9500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (8, 'Riddhi', 21, 'WB', 4500.00 ); 
SAVEPOINT sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000; 
ROLLBACK TO sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 7; 
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 8; 

COMMIT;

ROLLBACK TO sav1 - Pernyataan ini memutar kembali semua perubahan ke titik, di mana Anda telah menandai savepoint sav1.

Setelah itu, perubahan baru yang Anda buat akan dimulai.

Kontrol Transaksi Otomatis

Untuk menjalankan a COMMIT secara otomatis setiap kali file INSERT, UPDATE atau DELETE perintah dijalankan, Anda dapat mengatur AUTOCOMMIT variabel lingkungan sebagai -

SET AUTOCOMMIT ON;

Anda dapat mematikan mode komit otomatis menggunakan perintah berikut -

SET AUTOCOMMIT OFF;

Pada bab ini, kita akan membahas Tanggal dan Waktu di PL / SQL. Ada dua kelas tipe data terkait tanggal dan waktu di PL / SQL -

  • Tipe data datetime
  • Tipe data interval

Tipe data Datetime adalah -

  • DATE
  • TIMESTAMP
  • TIMESTAMP DENGAN ZONA WAKTU
  • TIMESTAMP DENGAN ZONA WAKTU LOKAL

Tipe data Interval adalah -

  • INTERVAL TAHUN KE BULAN
  • INTERVAL HARI KE KEDUA

Nilai Bidang untuk Tipe Data Waktu dan Interval

Kedua datetime dan interval tipe data terdiri dari fields. Nilai dari bidang ini menentukan nilai tipe data. Tabel berikut mencantumkan bidang dan kemungkinan nilainya untuk waktu tanggal dan interval.

Nama Bidang Nilai Tanggal Waktu yang Valid Nilai Interval yang Valid
TAHUN -4712 hingga 9999 (tidak termasuk tahun 0) Semua bilangan bulat bukan nol
BULAN 01 sampai 12 0 sampai 11
HARI 01 hingga 31 (dibatasi oleh nilai MONTH dan YEAR, sesuai dengan aturan kalender untuk lokal) Semua bilangan bulat bukan nol
JAM 00 sampai 23 0 sampai 23
MENIT 00 sampai 59 0 hingga 59
KEDUA

00 hingga 59,9 (n), di mana 9 (n) adalah ketepatan waktu pecahan detik

Bagian 9 (n) tidak berlaku untuk DATE.

0 hingga 59,9 (n), di mana 9 (n) adalah ketepatan dari detik pecahan interval
TIMEZONE_HOUR

-12 hingga 14 (kisaran mengakomodasi perubahan waktu musim panas)

Tidak berlaku untuk DATE atau TIMESTAMP.

Tak dapat diterapkan
TIMEZONE_MINUTE

00 sampai 59

Tidak berlaku untuk DATE atau TIMESTAMP.

Tak dapat diterapkan
TIMEZONE_REGION Tidak berlaku untuk DATE atau TIMESTAMP. Tak dapat diterapkan
TIMEZONE_ABBR Tidak berlaku untuk DATE atau TIMESTAMP. Tak dapat diterapkan

Jenis dan Fungsi Data Waktu

Berikut adalah tipe data Datetime -

TANGGAL

Ini menyimpan informasi tanggal dan waktu baik dalam tipe data karakter dan angka. Itu terbuat dari informasi tentang abad, tahun, bulan, tanggal, jam, menit, dan detik. Ini ditentukan sebagai -

TIMESTAMP

Ini adalah perpanjangan dari tipe data DATE. Ini menyimpan tahun, bulan, dan hari dari tipe data DATE, bersama dengan nilai jam, menit, dan detik. Berguna untuk menyimpan nilai waktu yang tepat.

TIMESTAMP DENGAN ZONA WAKTU

Ini adalah varian dari TIMESTAMP yang menyertakan nama wilayah zona waktu atau perbedaan nilai zona waktu. Perbedaan zona waktu adalah perbedaan (dalam jam dan menit) antara waktu lokal dan UTC. Tipe data ini berguna untuk mengumpulkan dan mengevaluasi informasi tanggal di seluruh wilayah geografis.

TIMESTAMP WITH LOCAL TIME ZONE

It is another variant of TIMESTAMP that includes a time zone offset in its value.

Following table provides the Datetime functions (where, x has the datetime value) −

S.No Function Name & Description
1

ADD_MONTHS(x, y);

Adds y months to x.

2

LAST_DAY(x);

Returns the last day of the month.

3

MONTHS_BETWEEN(x, y);

Returns the number of months between x and y.

4

NEXT_DAY(x, day);

Returns the datetime of the next day after x.

5

NEW_TIME;

Returns the time/day value from a time zone specified by the user.

6

ROUND(x [, unit]);

Rounds x.

7

SYSDATE();

Returns the current datetime.

8

TRUNC(x [, unit]);

Truncates x.

Timestamp functions (where, x has a timestamp value) −

S.No Function Name & Description
1

CURRENT_TIMESTAMP();

Returns a TIMESTAMP WITH TIME ZONE containing the current session time along with the session time zone.

2

EXTRACT({ YEAR | MONTH | DAY | HOUR | MINUTE | SECOND } | { TIMEZONE_HOUR | TIMEZONE_MINUTE } | { TIMEZONE_REGION | } TIMEZONE_ABBR ) FROM x)

Extracts and returns a year, month, day, hour, minute, second, or time zone from x.

3

FROM_TZ(x, time_zone);

Converts the TIMESTAMP x and the time zone specified by time_zone to a TIMESTAMP WITH TIMEZONE.

4

LOCALTIMESTAMP();

Returns a TIMESTAMP containing the local time in the session time zone.

5

SYSTIMESTAMP();

Returns a TIMESTAMP WITH TIME ZONE containing the current database time along with the database time zone.

6

SYS_EXTRACT_UTC(x);

Converts the TIMESTAMP WITH TIMEZONE x to a TIMESTAMP containing the date and time in UTC.

7

TO_TIMESTAMP(x, [format]);

Converts the string x to a TIMESTAMP.

8

TO_TIMESTAMP_TZ(x, [format]);

Converts the string x to a TIMESTAMP WITH TIMEZONE.

Examples

The following code snippets illustrate the use of the above functions −

Example 1

SELECT SYSDATE FROM DUAL;

Output

08/31/2012 5:25:34 PM

Example 2

SELECT TO_CHAR(CURRENT_DATE, 'DD-MM-YYYY HH:MI:SS') FROM DUAL;

Output

31-08-2012 05:26:14

Example 3

SELECT ADD_MONTHS(SYSDATE, 5) FROM DUAL;

Output

01/31/2013 5:26:31 PM

Example 4

SELECT LOCALTIMESTAMP FROM DUAL;

Output

8/31/2012 5:26:55.347000 PM

The Interval Data Types and Functions

Following are the Interval data types −

  • IINTERVAL YEAR TO MONTH − It stores a period of time using the YEAR and MONTH datetime fields.

  • INTERVAL DAY TO SECOND − It stores a period of time in terms of days, hours, minutes, and seconds.

Interval Functions

S.No Function Name & Description
1

NUMTODSINTERVAL(x, interval_unit);

Converts the number x to an INTERVAL DAY TO SECOND.

2

NUMTOYMINTERVAL(x, interval_unit);

Converts the number x to an INTERVAL YEAR TO MONTH.

3

TO_DSINTERVAL(x);

Converts the string x to an INTERVAL DAY TO SECOND.

4

TO_YMINTERVAL(x);

Converts the string x to an INTERVAL YEAR TO MONTH.

In this chapter, we will discuss the DBMS Output in PL/SQL. The DBMS_OUTPUT is a built-in package that enables you to display output, debugging information, and send messages from PL/SQL blocks, subprograms, packages, and triggers. We have already used this package throughout our tutorial.

Let us look at a small code snippet that will display all the user tables in the database. Try it in your database to list down all the table names −

BEGIN 
   dbms_output.put_line  (user || ' Tables in the database:'); 
   FOR t IN (SELECT table_name FROM user_tables) 
   LOOP 
      dbms_output.put_line(t.table_name); 
   END LOOP; 
END; 
/

DBMS_OUTPUT Subprograms

The DBMS_OUTPUT package has the following subprograms −

S.No Subprogram & Purpose
1

DBMS_OUTPUT.DISABLE;

Disables message output.

2

DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000);

Enables message output. A NULL value of buffer_size represents unlimited buffer size.

3

DBMS_OUTPUT.GET_LINE (line OUT VARCHAR2, status OUT INTEGER);

Retrieves a single line of buffered information.

4

DBMS_OUTPUT.GET_LINES (lines OUT CHARARR, numlines IN OUT INTEGER);

Retrieves an array of lines from the buffer.

5

DBMS_OUTPUT.NEW_LINE;

Puts an end-of-line marker.

6

DBMS_OUTPUT.PUT(item IN VARCHAR2);

Places a partial line in the buffer.

7

DBMS_OUTPUT.PUT_LINE(item IN VARCHAR2);

Places a line in the buffer.

Example

DECLARE 
   lines dbms_output.chararr; 
   num_lines number; 
BEGIN 
   -- enable the buffer with default size 20000 
   dbms_output.enable; 
   
   dbms_output.put_line('Hello Reader!'); 
   dbms_output.put_line('Hope you have enjoyed the tutorials!'); 
   dbms_output.put_line('Have a great time exploring pl/sql!'); 
  
   num_lines := 3; 
  
   dbms_output.get_lines(lines, num_lines); 
  
   FOR i IN 1..num_lines LOOP 
      dbms_output.put_line(lines(i)); 
   END LOOP; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Hello Reader! 
Hope you have enjoyed the tutorials! 
Have a great time exploring pl/sql!  

PL/SQL procedure successfully completed.

In this chapter, we will discuss Object-Oriented PL/SQL. PL/SQL allows defining an object type, which helps in designing object-oriented database in Oracle. An object type allows you to create composite types. Using objects allow you to implement real world objects with specific structure of data and methods for operating it. Objects have attributes and methods. Attributes are properties of an object and are used for storing an object's state; and methods are used for modeling its behavior.

Objects are created using the CREATE [OR REPLACE] TYPE statement. Following is an example to create a simple address object consisting of few attributes −

CREATE OR REPLACE TYPE address AS OBJECT 
(house_no varchar2(10), 
 street varchar2(30), 
 city varchar2(20), 
 state varchar2(10), 
 pincode varchar2(10) 
); 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Let's create one more object customer where we will wrap attributes and methods together to have object-oriented feeling −

CREATE OR REPLACE TYPE customer AS OBJECT 
(code number(5), 
 name varchar2(30), 
 contact_no varchar2(12), 
 addr address, 
 member procedure display 
); 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Instantiating an Object

Defining an object type provides a blueprint for the object. To use this object, you need to create instances of this object. You can access the attributes and methods of the object using the instance name and the access operator (.) as follows −

DECLARE 
   residence address; 
BEGIN 
   residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301'); 
   dbms_output.put_line('House No: '|| residence.house_no); 
   dbms_output.put_line('Street: '|| residence.street); 
   dbms_output.put_line('City: '|| residence.city); 
   dbms_output.put_line('State: '|| residence.state); 
   dbms_output.put_line('Pincode: '|| residence.pincode); 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

House No: 103A 
Street: M.G.Road 
City: Jaipur 
State: Rajasthan 
Pincode: 201301  

PL/SQL procedure successfully completed.

Member Methods

Member methods are used for manipulating the attributes of the object. You provide the declaration of a member method while declaring the object type. The object body defines the code for the member methods. The object body is created using the CREATE TYPE BODY statement.

Constructors are functions that return a new object as its value. Every object has a system defined constructor method. The name of the constructor is same as the object type. For example −

residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301');

The comparison methods are used for comparing objects. There are two ways to compare objects −

Map method

The Map method is a function implemented in such a way that its value depends upon the value of the attributes. For example, for a customer object, if the customer code is same for two customers, both customers could be the same. So the relationship between these two objects would depend upon the value of code.

Order method

The Order method implements some internal logic for comparing two objects. For example, for a rectangle object, a rectangle is bigger than another rectangle if both its sides are bigger.

Using Map method

Let us try to understand the above concepts using the following rectangle object −

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 member procedure display, 
 map member function measure return number 
); 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Creating the type body −

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN  
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   MAP MEMBER FUNCTION measure return number IS 
   BEGIN 
      return (sqrt(length*length + width*width)); 
   END measure; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type body created.

Now using the rectangle object and its member functions −

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
   r3 rectangle; 
   inc_factor number := 5; 
BEGIN 
   r1 := rectangle(3, 4); 
   r2 := rectangle(5, 7); 
   r3 := r1.enlarge(inc_factor); 
   r3.display;  
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Length: 8 
Width: 9 
Length: 5 
Width: 7  

PL/SQL procedure successfully completed.

Using Order method

Now, the same effect could be achieved using an order method. Let us recreate the rectangle object using an order method −

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member procedure display, 
 order member function measure(r rectangle) return number 
); 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Creating the type body −

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   ORDER MEMBER FUNCTION measure(r rectangle) return number IS 
   BEGIN 
      IF(sqrt(self.length*self.length + self.width*self.width)> 
         sqrt(r.length*r.length + r.width*r.width)) then 
         return(1); 
      ELSE 
         return(-1); 
      END IF; 
   END measure; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type body created.

Using the rectangle object and its member functions −

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
BEGIN 
   r1 := rectangle(23, 44); 
   r2 := rectangle(15, 17); 
   r1.display; 
   r2.display; 
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Length: 23 
Width: 44 
Length: 15 
Width: 17 
Length: 23 
Width: 44 

PL/SQL procedure successfully completed.

Inheritance for PL/SQL Objects

PL/SQL allows creating object from the existing base objects. To implement inheritance, the base objects should be declared as NOT FINAL. The default is FINAL.

The following programs illustrate the inheritance in PL/SQL Objects. Let us create another object named TableTop, this is inherited from the Rectangle object. For this, we need to create the base rectangle object −

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 NOT FINAL member procedure display) NOT FINAL 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Creating the base type body −

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display; 
END; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type body created.

Creating the child object tabletop

CREATE OR REPLACE TYPE tabletop UNDER rectangle 
(   
   material varchar2(20), 
   OVERRIDING member procedure display 
) 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.

Creating the type body for the child object tabletop

CREATE OR REPLACE TYPE BODY tabletop AS 
OVERRIDING MEMBER PROCEDURE display IS 
BEGIN 
   dbms_output.put_line('Length: '|| length); 
   dbms_output.put_line('Width: '|| width); 
   dbms_output.put_line('Material: '|| material); 
END display; 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type body created.

Using the tabletop object and its member functions −

DECLARE 
   t1 tabletop; 
   t2 tabletop; 
BEGIN 
   t1:= tabletop(20, 10, 'Wood'); 
   t2 := tabletop(50, 30, 'Steel'); 
   t1.display; 
   t2.display; 
END;
/

When the above code is executed at the SQL prompt, it produces the following result −

Length: 20 
Width: 10 
Material: Wood 
Length: 50 
Width: 30 
Material: Steel  

PL/SQL procedure successfully completed.

Abstract Objects in PL/SQL

The NOT INSTANTIABLE clause allows you to declare an abstract object. You cannot use an abstract object as it is; you will have to create a subtype or child type of such objects to use its functionalities.

For example,

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 NOT INSTANTIABLE NOT FINAL MEMBER PROCEDURE display)  
 NOT INSTANTIABLE NOT FINAL 
/

When the above code is executed at the SQL prompt, it produces the following result −

Type created.