PL / SQL - String
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. String tersebut dilapisi kanan dengan spasi sepanjang yang ditentukan.
Variable-length strings - Dalam string tersebut, panjang maksimum hingga 32.767, untuk string ditentukan dan tidak ada padding 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 bisa 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]); Mengembalikan 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.