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 &lttab_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