PL / SQL - Tipe Data
Pada bab ini, kita akan membahas Tipe Data dalam 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
Jenis 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 Integer yang ditandatangani dalam kisaran -2.147.483.648 hingga 2.147.483.647, direpresentasikan dalam 32 bit |
2 | BINARY_INTEGER Integer 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 Tipe floating-point khusus ANSI dan IBM dengan presisi maksimum 126 digit biner (sekitar 38 digit desimal) |
11 | INT Tipe integer spesifik 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, dan 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.