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.