H2 Database - Buat

CREATE adalah perintah SQL umum yang digunakan untuk membuat Tabel, Skema, Urutan, Tampilan, dan Pengguna di server H2 Database.

Buat tabel

Buat Tabel adalah perintah yang digunakan untuk membuat tabel yang ditentukan pengguna di database saat ini.

Sintaksis

Berikut ini adalah sintaks umum untuk perintah Buat Tabel.

CREATE [ CACHED | MEMORY ] [ TEMP | [ GLOBAL | LOCAL ] TEMPORARY ] 
TABLE [ IF NOT EXISTS ] name 
[ ( { columnDefinition | constraint } [,...] ) ] 
[ ENGINE tableEngineName [ WITH tableEngineParamName [,...] ] ] 
[ NOT PERSISTENT ] [ TRANSACTIONAL ] 
[ AS select ]

Dengan menggunakan sintaks generik dari perintah Buat Tabel, kita dapat membuat berbagai jenis tabel seperti tabel yang di-cache, tabel memori, dan tabel sementara. Berikut adalah daftar untuk mendeskripsikan klausa yang berbeda dari sintaks yang diberikan.

  • CACHED- Tabel yang di-cache adalah tipe default untuk tabel biasa. Artinya jumlah baris tidak dibatasi oleh memori utama.

  • MEMORY- Tabel memori adalah tipe default untuk tabel sementara. Ini berarti tabel memori tidak boleh terlalu besar dan data indeks disimpan di memori utama.

  • TEMPORARY- Tabel sementara dihapus saat menutup atau membuka database. Pada dasarnya, tabel sementara terdiri dari dua jenis -

    • Tipe GLOBAL - Dapat diakses oleh semua koneksi.

    • Tipe LOKAL - Dapat diakses oleh koneksi saat ini.

    Tipe default untuk tabel sementara adalah tipe global. Indeks tabel sementara disimpan di memori utama, kecuali tabel sementara dibuat menggunakan CREATE CACHED TABLE.

  • ENGINE - Opsi ENGINE hanya diperlukan ketika implementasi tabel kustom digunakan.

  • NOT PERSISTENT - Ini adalah pengubah untuk menyimpan data tabel lengkap di dalam memori dan semua baris akan hilang saat database ditutup.

  • TRANSACTIONAL - Ini adalah kata kunci yang melakukan transaksi terbuka dan perintah ini hanya mendukung tabel sementara.

Contoh

Dalam contoh ini, mari kita buat tabel bernama tutorials_tbl menggunakan data yang diberikan berikut.

Sr Tidak Nama kolom Tipe data
1 Indo Int
2 Judul Varchar (50)
3 Penulis Varchar (20)
4 Tanggal penyerahan Tanggal

Kueri berikut digunakan untuk membuat tabel tutorials_tbl bersama dengan data kolom yang diberikan.

CREATE TABLE tutorials_tbl ( 
   id INT NOT NULL, 
   title VARCHAR(50) NOT NULL, 
   author VARCHAR(20) NOT NULL, 
   submission_date DATE 
);

Kueri di atas menghasilkan keluaran berikut.

(0) rows effected

Buat Skema

Buat Skema adalah perintah yang digunakan untuk membuat skema yang bergantung pada pengguna di bawah otorisasi tertentu (di bawah pengguna yang saat ini terdaftar).

Sintaksis

Berikut ini adalah sintaks umum dari perintah Buat Skema.

CREATE SCHEMA [ IF NOT EXISTS ] name [ AUTHORIZATION ownerUserName ]

Dalam sintaks umum di atas, AUTHORIZATION adalah kata kunci yang digunakan untuk memberikan nama pengguna masing-masing. Perintah ini bersifat opsional yang artinya jika kita tidak memberikan nama pengguna, maka itu akan mempertimbangkan pengguna saat ini. Pengguna yang menjalankan perintah harus memiliki hak admin, serta pemiliknya.

Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Contoh

Dalam contoh ini, mari kita buat skema bernama test_schema di bawah pengguna SA, menggunakan perintah berikut.

CREATE SCHEMA test_schema AUTHORIZATION sa;

Perintah di atas menghasilkan keluaran sebagai berikut.

(0) rows effected

Buat Urutan

Urutan adalah konsep yang digunakan untuk menghasilkan angka dengan mengikuti urutan id atau nilai kolom acak.

Sintaksis

Berikut ini adalah sintaks umum dari perintah create sequence.

CREATE SEQUENCE [ IF NOT EXISTS ] newSequenceName [ START WITH long ] 
[ INCREMENT BY long ] 
[ MINVALUE long | NOMINVALUE | NO MINVALUE ] 
[ MAXVALUE long | NOMAXVALUE | NO MAXVALUE ] 
[ CYCLE long | NOCYCLE | NO CYCLE ] 
[ CACHE long | NOCACHE | NO CACHE ]

Sintaks generik ini digunakan untuk membuat urutan. Jenis data urutan adalahBIGINT. Dalam urutan ini, nilai tidak pernah digunakan kembali, bahkan saat transaksi didukung roll.

Contoh

Dalam contoh ini, mari kita buat urutan bernama SEQ_ID, menggunakan kueri berikut.

CREATE SEQUENCE SEQ_ID;

Kueri di atas menghasilkan keluaran berikut.

(0) rows effected