DB2 - Tabel
Tabel adalah struktur logis yang dikelola oleh manajer Database. Dalam sebuah tabel, setiap blok vertikal disebut kolom (Tuple) dan setiap blok horizontal disebut sebagai baris (Entity). Kumpulan data yang disimpan dalam bentuk kolom dan baris dikenal dengan tabel. Dalam tabel, setiap kolom memiliki tipe data yang berbeda. Tabel digunakan untuk menyimpan data persisten.
Jenis tabel
- Base Tables: Mereka menyimpan data yang persisten. Ada berbagai jenis tabel dasar, termasuk:
- Regular Tables: Tabel tujuan umum, Tabel umum dengan indeks adalah tabel tujuan umum.
- Multidimensional Clustering Table (MDC): Jenis tabel ini secara fisik berkerumun di lebih dari satu kunci, dan digunakan untuk memelihara lingkungan database yang besar. Jenis tabel ini tidak didukung di DB2 pureScale.
- Insert time clustering Table (ITC): Mirip dengan tabel MDC, baris dikelompokkan pada saat dimasukkan ke dalam tabel. Mereka dapat menjadi tabel yang dipartisi. Mereka juga, tidak mendukung lingkungan pureScale.
- Range-Clustered tables Table (RCT): Jenis tabel ini memberikan akses data yang cepat dan langsung. Ini diimplementasikan sebagai cluster berurutan. Setiap record dalam tabel memiliki ID record. Jenis tabel ini digunakan di mana data dikelompokkan dengan erat dengan satu atau beberapa kolom dalam tabel. Jenis tabel ini juga tidak mendukung DB2 pureScale.
- Partitioned Tables: Jenis tabel ini digunakan dalam skema organisasi data, di mana data tabel dibagi menjadi beberapa objek penyimpanan. Partisi data dapat ditambahkan ke, dilampirkan dan dilepaskan dari tabel yang dipartisi. Anda dapat menyimpan beberapa partisi data dari sebuah tabel dalam satu tablespace.
- Temporal Tables: Sejarah tabel dalam database disimpan dalam tabel temporal seperti detail modifikasi yang dilakukan sebelumnya.
- Temporary Tables: Untuk pekerjaan sementara dari operasi database yang berbeda, Anda perlu menggunakan tabel sementara. Tabel sementara (DGTT) tidak muncul di katalog sistem, kolom XML tidak dapat digunakan dalam tabel sementara yang dibuat.
- Materialized Query Tables: MQT dapat digunakan untuk meningkatkan kinerja kueri. Tipe tabel ini ditentukan oleh kueri, yang digunakan untuk menentukan data dalam tabel.
Membuat Tabel
Sintaks berikut membuat tabel:
Syntax: [Untuk membuat tabel baru]
db2 create table <schema_name>.<table_name>
(column_name column_type....) in <tablespace_name>
Example: Kami membuat tabel untuk menyimpan detail "karyawan" dalam skema "profesional". Tabel ini memiliki field “id, name, jobrole, joindate, gaji” dan data tabel ini akan disimpan di tablespace “ts1”.
db2 create table professional.employee(id int, name
varchar(50),jobrole varchar(30),joindate date,
salary double) in ts1
Output:
DB20000I The SQL command completed successfully.
Detail tabel daftar
Sintaks berikut digunakan untuk membuat daftar detail tabel:
Syntax: [Untuk melihat daftar tabel yang dibuat dengan skema]
db2 select tabname, tabschema, tbspace from syscat.tables
Example: [Untuk melihat daftar tabel di database saat ini]
db2 select tabname, tabschema, tbspace from syscat.tables
Output:
TABNAME TABSCHEMA TBSPACE
------------ ------------- --------
EMPLOYEE PROFESSIONAL TS1
1 record(s) selected.
Daftar kolom dalam sebuah tabel
Sintaks berikut mencantumkan kolom dalam tabel:
Syntax: [Untuk melihat kolom dan tipe data dari sebuah tabel]
db2 describe table <table_name>
Example: [Untuk melihat kolom dan tipe data pada tabel 'karyawan']
db2 describe table professional.employee
Output:
Data type Column
Column name schema Data type name Length Scale Nulls
------ ----- --------- ----------------- --------- ----- ------
ID SYSIBM INTEGER 4 0 Yes
NAME SYSIBM VARCHAR 50 0 Yes
JOBROLE SYSIBM VARCHAR 30 0 Yes
JOINDATE SYSIBM DATE 4 0 Yes
SALARY SYSIBM DOUBLE 8 0 Yes
5 record(s) selected.
Kolom Tersembunyi
Anda dapat menyembunyikan seluruh kolom tabel. Jika Anda memanggil kueri "pilih * dari", kolom tersembunyi tidak dikembalikan dalam tabel yang dihasilkan. Saat Anda memasukkan data ke dalam tabel, pernyataan "INSERT" tanpa daftar kolom tidak mengharapkan nilai untuk setiap kolom yang tersembunyi secara implisit. Jenis kolom ini sangat direferensikan dalam tabel kueri yang terwujud. Jenis kolom ini tidak mendukung pembuatan tabel sementara.
Membuat tabel dengan kolom tersembunyi
Sintaks berikut membuat tabel dengan kolom tersembunyi:
Syntax: [Untuk membuat tabel dengan kolom tersembunyi]
db2 create table <tab_name> (col1 datatype,col2 datatype
implicitly hidden)
Example: [Untuk membuat tabel 'pelanggan' dengan kolom tersembunyi 'telepon']
db2 create table professional.customer(custid integer not
null, fullname varchar(100), phone char(10)
implicitly hidden)
Memasukkan nilai data dalam tabel
Sintaks berikut menyisipkan nilai dalam tabel:
Syntax: [Untuk memasukkan nilai ke dalam tabel]
db2 insert into <tab_name>(col1,col2,...)
values(val1,val2,..)
Example: [Untuk memasukkan nilai dalam tabel 'customer']
db2 insert into professional.customer(custid, fullname, phone)
values(100,'ravi','9898989')
db2 insert into professional.customer(custid, fullname, phone)
values(101,'krathi','87996659')
db2 insert into professional.customer(custid, fullname, phone)
values(102,'gopal','768678687')
Output:
DB20000I The SQL command completed successfully.
Mengambil nilai dari tabel
Sintaks berikut mengambil nilai dari tabel:
Syntax: [Untuk mengambil nilai dari tabel]
db2 select * from <tab_name>
Example: [Untuk mengambil nilai dari tabel 'customer']
db2 select * from professional.customer
Output:
CUSTID FULLNAME
----------- ------------------------
100 ravi
101 krathi
102 gopal
3 record(s) selected.
Mengambil nilai dari tabel termasuk kolom tersembunyi
Sintaks berikut mengambil nilai dari kolom yang dipilih:
Syntax: [Untuk mengambil nilai kolom tersembunyi yang dipilih dari tabel]
db2 select col1,col2,col3 from <tab_name>
Example: [Untuk mengambil hasil nilai kolom yang dipilih dari tabel]
db2 select custid,fullname,phone from professional.customer
Output:
CUSTID FULLNAME PHONE
------- --------- ------------
100 ravi 9898989
101 krathi 87996659
102 gopal 768678687
3 record(s) selected.
Jika Anda ingin melihat data di kolom tersembunyi, Anda perlu menjalankan perintah "DESCRIBE".
Syntax:
db2 describe table <table_name> show detail
Example:
db2 describe table professional.customer show detail
Output:
Column name Data type schema Data type name Column
column Partitionkey code
Length Scale Nulls
number sequence page Hidden Default
--------------- -------------------- --------------- -------- ----
---- -------- ---------- ------------- -------- ----------- ------
---
CUSTID SYSIBM INTEGER 4 0
No 0 0 0 No
FULLNAME SYSIBM VARCHAR 100 0
Yes 1 0 1208 No
PHONE SYSIBM CHARACTER 10 0
Yes 2 0 1208 Implicitly
3 record(s) selected.
Mengubah jenis kolom tabel
Anda dapat mengubah struktur tabel kami menggunakan perintah "ubah" ini sebagai berikut:
Syntax:
db2 alter table <tab_name> alter column <col_name> set data type <data_type>
Example: [Untuk mengubah tipe data kolom "id" dari "int" menjadi "bigint" untuk tabel karyawan]
db2 alter table professional.employee alter column id set data type bigint
Output::
DB20000I The SQL command completed successfully.
Mengubah nama kolom
Anda dapat mengubah nama kolom seperti yang ditunjukkan di bawah ini:
Syntax: [Untuk mengubah nama kolom dari nama lama menjadi nama baru tabel]
db2 alter table <tab_name> rename column <old_name> to <new_name>
Example: [Untuk mengubah nama kolom dari "fullname" menjadi "custname" di tabel "customers".]
db2 alter table professional.customer rename column fullname to custname
Menjatuhkan tabel
Untuk menghapus tabel apa pun, Anda perlu menggunakan perintah "DROP" sebagai berikut:
Syntax:
db2 drop table <tab_name>
Example: [Untuk menghapus database formulir tabel pelanggan]
db2 drop table professional.customers
Untuk menghapus seluruh hierarki tabel (termasuk pemicu dan relasi), Anda perlu menggunakan perintah “DROP TABLE HIERARCHY”.
Syntax:
db2 drop table hierarchy <tab_name>
Example: [Untuk menghapus seluruh hierarki tabel 'pelanggan']
db2 drop table hierarchy professional.customers