H2 Database - Panduan Cepat

H2 adalah database Java ringan open-source. Ini dapat tertanam dalam aplikasi Java atau dijalankan dalam mode klien-server. Terutama, database H2 dapat dikonfigurasi untuk dijalankan sebagai database inmemory, yang berarti bahwa data tidak akan bertahan di disk. Karena basis data tertanam, ini tidak digunakan untuk pengembangan produksi, tetapi sebagian besar digunakan untuk pengembangan dan pengujian.

Database ini dapat digunakan dalam mode tertanam atau dalam mode server. Berikut adalah fitur utama dari database H2 -

  • Sangat cepat, open source, JDBC API
  • Tersedia dalam mode tertanam dan server; database dalam memori
  • Aplikasi Konsol berbasis browser
  • Jejak kecil - Ukuran file jar sekitar 1,5MB

Fitur Database H2

Fitur utama dari H2 Database adalah sebagai berikut -

  • Ini adalah mesin database yang sangat cepat.

  • H2 adalah open source dan ditulis di Java.

  • Ini mendukung SQL standar dan JDBC API. Itu dapat menggunakan driver ODBC PostgreSQL juga.

  • Ini memiliki mode tertanam dan Server.

  • H2 mendukung clustering dan multi-version concurrency.

  • Ini memiliki fitur keamanan yang kuat.

Fitur tambahan

Berikut adalah beberapa fitur tambahan dari H2 Database -

  • H2 adalah database dan tabel berbasis disk atau dalam memori, dukungan database hanya-baca, tabel sementara.

  • H2 menyediakan dukungan transaksi (baca berkomitmen), koneksi ganda 2-fase, penguncian tingkat tabel.

  • H2 adalah pengoptimal berbasis biaya, menggunakan algoritme genetik untuk kueri kompleks, zeroadministration.

  • H2 berisi dukungan kumpulan hasil yang dapat digulir dan dapat diperbarui, kumpulan hasil besar, penyortiran hasil eksternal, fungsi dapat mengembalikan kumpulan hasil.

  • H2 mendukung database terenkripsi (AES), enkripsi sandi SHA-256, fungsi enkripsi, dan SSL.

Komponen dalam Database H2

Untuk menggunakan H2 Database, Anda harus memiliki komponen berikut -

  • Sebuah browser web
  • Server konsol H2

Ini adalah aplikasi klien / server, jadi server dan klien (browser) diperlukan untuk menjalankannya.

H2 adalah database yang ditulis di Java. Kami dapat dengan mudah menyematkan database ini ke aplikasi kami dengan menggunakan JDBC. Kami dapat menjalankan ini di banyak platform berbeda atau versi Java Runtime Environment apa pun. Namun, sebelum menginstal database, harus ada Java yang diinstal di sistem.

Verifikasi Instalasi Java

Jika JDK diinstal di sistem, coba perintah berikut untuk memverifikasi versi Java.

java –version

Jika JDk berhasil diinstal di sistem, maka kita akan mendapatkan keluaran sebagai berikut.

java version "1.8.0_91" 
Java(TM) SE Runtime Environment (build 1.8.0_91-b14) 
Java HotSpot(TM) 64-Bit Server VM (build 25.91-b14, mixed mode)

Jika JDK tidak diinstal di sistem, kunjungi tautan berikut untuk Menginstal JDK .

Instal H2 Database

Kami dapat menjalankan database ini di berbagai platform. Pada bab ini, kita akan belajar tentang instalasi H2 Database di Windows.

Berikut adalah langkah-langkah untuk menginstal H2 Database pada sistem operasi Windows.

Langkah 1: Unduh File Pengaturan H2

Unduh versi terbaru H2 Database dari tautan yang diberikan. Di tautan ini, Anda akan mendapatkan versi terbaru database H2 dalam dua jenis. Salah satunya adalah jenis Windows Installer (yaitu file .exe) dan yang kedua adalah file zip Platform-Independent untuk sistem operasi lain.

Klik penginstal Windows untuk mengunduh database H2 yang dapat didukung Windows setelah mengunduh file .exe. Dalam hal ini, kami menggunakan H2 Database dengan versi 1.4.192.

Langkah 2: Instal Database H2

Setelah mengunduh, kami mendapatkan file penginstal H2 Windows (yaitu h2-setup-yyyy-mm-dd.exe) di direktori Unduhan. Untuk memulai proses instalasi H2 Database, klik dua kali pada file penginstal.

Layar berikut adalah langkah pertama dalam proses instalasi. Berikan jalur di mana kami ingin menginstal server database H2 seperti yang ditunjukkan pada tangkapan layar berikut.

Seperti yang terlihat pada gambar di atas, secara default dibutuhkan C:\ProgramFiles (x86)\H2sebagai folder tujuan. Klik berikutnya untuk melanjutkan ke langkah berikutnya. Layar berikut muncul.

Pada gambar di atas, klik tombol Instal untuk memulai proses instalasi. Setelah instalasi, kami mendapatkan tangkapan layar berikut.

Klik Selesai untuk menyelesaikan proses instalasi.

Langkah 3: Verifikasi Instalasi Database H2

Setelah penginstalan, izinkan kami memverifikasi penginstalan database di sistem. Klik Windows → ketik H2 Console → Klik ikon konsol H2. Hubungkan ke URLhttp://localhost:8082. Pada saat menghubungkan, database H2 akan meminta registrasi database seperti yang ditunjukkan pada gambar layar berikut.

Isi semua detail di kotak dialog di atas seperti Pengaturan Tersimpan, Nama Pengaturan, Kelas Driver, URL JDBC, Nama Pengguna, dan Kata Sandi. Di URL JDBC, tentukan letak database dan nama database. User Name dan Password adalah field untuk nama pengguna dan kata sandi database. Klik Hubungkan.

Halaman selamat datang Database muncul seperti yang ditunjukkan pada gambar berikut.

Perintah Select digunakan untuk mengambil data record dari sebuah tabel atau beberapa tabel. Jika kita mendesain kueri pemilihan, maka ia mengembalikan data dalam bentuk tabel hasil yang disebutresult sets.

Sintaksis

Sintaks dasar pernyataan SELECT adalah sebagai berikut -

SELECT [ TOP term ] [ DISTINCT | ALL ] selectExpression [,...] 
FROM tableExpression [,...] [ WHERE expression ] 
[ GROUP BY expression [,...] ] [ HAVING expression ] 
[ { UNION [ ALL ] | MINUS | EXCEPT | INTERSECT } select ] [ ORDER BY order [,...] ] 
[ [ LIMIT expression ] [ OFFSET expression ] [ SAMPLE_SIZE rowCountInt ] ] 
[ FOR UPDATE ]

Untuk mengambil semua bidang yang tersedia, gunakan sintaks berikut.

SELECT * FROM table_name;

Contoh

Pertimbangkan tabel CUSTOMER yang memiliki catatan berikut -

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Untuk mendapatkan tabel pelanggan bersama dengan data yang diberikan, jalankan kueri berikut.

CREATE TABLE CUSTOMER (id number, name varchar(20), age number, address varchar(20), 
salary number);  

INSERT into CUSTOMER values (1, 'Ramesh', 32, 'Ahmedabad', 2000); 
INSERT into CUSTOMER values (2, 'Khilan', 25, 'Delhi', 1500); 
INSERT into CUSTOMER values (3, 'kaushik', 23, 'Kota', 2000); 
INSERT into CUSTOMER values (4, 'Chaitali', 25, 'Mumbai', 6500); 
INSERT into CUSTOMER values (5, 'Hardik', 27, 'Bhopal', 8500); 
INSERT into CUSTOMER values (6, 'Komal', 22, 'MP', 4500); 
INSERT into CUSTOMER values (7, 'Muffy', 24, 'Indore', 10000);

Perintah berikut adalah contoh, yang akan mengambil kolom ID, Nama dan Gaji dari pelanggan yang tersedia di tabel PELANGGAN.

SELECT ID, NAME, SALARY FROM CUSTOMERS;

Perintah di atas menghasilkan hasil sebagai berikut.

+----+----------+----------+ 
| ID | NAME     | SALARY   | 
+----+----------+----------+ 
|  1 | Ramesh   |  2000.00 | 
|  2 | Khilan   |  1500.00 | 
|  3 | kaushik  |  2000.00 | 
|  4 | Chaitali |  6500.00 | 
|  5 | Hardik   |  8500.00 | 
|  6 | Komal    |  4500.00 | 
|  7 | Muffy    | 10000.00 | 
+----+----------+----------+

Gunakan query berikut untuk mengambil semua field dari tabel CUSTOMERS.

SQL> SELECT * FROM CUSTOMERS;

Kueri di atas menghasilkan hasil sebagai berikut -

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Pernyataan SQL INSERT digunakan untuk menambahkan baris data baru ke tabel dalam database.

Sintaksis

Berikut ini adalah sintaks dasar dari pernyataan INSERT INTO.

INSERT INTO tableName 
{ [ ( columnName [,...] ) ] 
{ VALUES 
{ ( { DEFAULT | expression } [,...] ) } [,...] | [ DIRECT ] [ SORTED ] select } } | 
{ SET { columnName = { DEFAULT | expression } } [,...] }

Dengan menggunakan pernyataan INSERT ini, kita dapat memasukkan record baru atau baris baru ke dalam tabel. Saat menggunakan klausa DIRECT, hasil secara langsung terpengaruh ke tabel target tanpa langkah perantara. Namun, saat menambahkan nilai untuk semua kolom pada tabel, pastikan urutan nilai dalam urutan yang sama dengan kolom pada tabel.

Contoh

Mari kita ambil contoh dan mencoba memasukkan catatan yang diberikan berikut ini ke dalam tabel Pelanggan.

Indo Nama Usia Alamat Gaji
1 Ramesh 32 Ahmedabad 2000
2 Khilan 25 Delhi 1500
3 Kaushik 23 Kota 2000
4 Chaitail 25 Mumbai 6500
5 Hardik 27 Bhopal 8500
6 Komal 22 MP 4500
7 Muffy 24 Indore 10000

Kita bisa mendapatkan semua catatan yang diberikan ke dalam tabel pelanggan dengan menjalankan perintah berikut.

INSERT INTO CUSTOMER VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000); 
INSERT INTO CUSTOMER VALUES (2, 'Khilan', 25, 'Delhi', 1500); 
INSERT INTO CUSTOMER VALUES (3, 'kaushik', 23, 'Kota', 2000); 
INSERT INTO CUSTOMER VALUES (4, 'Chaitali', 25, 'Mumbai', 6500); 
INSERT INTO CUSTOMER VALUES (5, 'Hardik', 27, 'Bhopal', 8500); 
INSERT INTO CUSTOMER VALUES (6, 'Komal', 22, 'MP', 4500); 
INSERT INTO CUSTOMER VALUES (7, 'Muffy', 24, 'Indore', 10000);

Kueri UPDATE digunakan untuk memperbarui atau mengubah catatan yang ada dalam tabel. Kita dapat menggunakan klausa WHERE dengan kueri UPDATE untuk memperbarui baris yang dipilih, jika tidak, semua baris akan terpengaruh.

Sintaksis

Berikut ini adalah sintaks dasar dari kueri UPDATE.

UPDATE tableName [ [ AS ] newTableAlias ] SET 
{ { columnName = { DEFAULT | expression } } [,...] } | 
{ ( columnName [,...] ) = ( select ) } 
[ WHERE expression ] [ ORDER BY order [,...] ] [ LIMIT expression ]

Dalam sintaks UPDATE ini, kita dapat menggabungkan lebih dari satu kondisi dengan menggunakan klausa AND atau OR.

Contoh

Pertimbangkan tabel CUSTOMER yang memiliki catatan berikut.

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Jika Anda ingin mendapatkan tabel pelanggan bersama dengan data yang diberikan, jalankan kueri berikut.

CREATE TABLE CUSTOMER (id number, name varchar(20), age number, address varchar(20), 
   salary number);  
INSERT into CUSTOMER values (1, 'Ramesh', 32, 'Ahmedabad', 2000); 
INSERT into CUSTOMER values (2, 'Khilan', 25, 'Delhi', 1500); 
INSERT into CUSTOMER values (3, 'kaushik', 23, 'Kota', 2000); 
INSERT into CUSTOMER values (4, 'Chaitali', 25, 'Mumbai', 6500); 
INSERT into CUSTOMER values (5, 'Hardik', 27, 'Bhopal', 8500); 
INSERT into CUSTOMER values (6, 'Komal', 22, 'MP', 4500); 
INSERT into CUSTOMER values (7, 'Muffy', 24, 'Indore', 10000);

Perintah berikut adalah contoh, yang akan memperbarui ALAMAT untuk pelanggan yang ID-nya 6 -

UPDATE CUSTOMERS SET ADDRESS = 'Pune' WHERE ID = 6;

Sekarang, tabel CUSTOMERS akan memiliki record berikut. Kami dapat memeriksa catatan tabel pelanggan dengan menjalankan kueri berikut.

SELECT * FROM CUSTOMERS;

Kueri di atas menghasilkan hasil sebagai berikut.

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | Pune      |  4500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Untuk mengubah semua nilai kolom ALAMAT dan SALARY pada tabel CUSTOMERS, kita tidak perlu menggunakan klausa WHERE. Kueri UPDATE adalah sebagai berikut -

UPDATE CUSTOMERS SET ADDRESS = 'Pune', SALARY = 1000.00;

Sekarang, tabel CUSTOMERS akan memiliki record berikut. Kami dapat memeriksa catatan tabel pelanggan dengan menjalankan kueri berikut.

SELECT * FROM CUSTOMERS;

Kueri di atas menghasilkan hasil sebagai berikut -

+----+----------+-----+---------+---------+ 
| ID | NAME     | AGE | ADDRESS | SALARY  | 
+----+----------+-----+---------+---------+ 
|  1 | Ramesh   |  32 | Pune    | 1000.00 | 
|  2 | Khilan   |  25 | Pune    | 1000.00 | 
|  3 | kaushik  |  23 | Pune    | 1000.00 | 
|  4 | Chaitali |  25 | Pune    | 1000.00 | 
|  5 | Hardik   |  27 | Pune    | 1000.00 | 
|  6 | Komal    |  22 | Pune    | 1000.00 | 
|  7 | Muffy    |  24 | Pune    | 1000.00 | 
+----+----------+-----+---------+---------+

Kueri SQL DELETE digunakan untuk menghapus rekaman yang sudah ada dari tabel. Kita dapat menggunakan klausa WHERE dengan query DELETE untuk menghapus record yang dipilih, jika tidak semua record akan dihapus.

Sintaksis

Berikut ini adalah sintaks kueri umum dari perintah hapus.

DELETE [ TOP term ] FROM tableName [ WHERE expression ] [ LIMIT term ]

Sintaks di atas menghapus baris dari tabel. Jika TOP atau LIMIT ditentukan, paling banyak jumlah baris yang ditentukan akan dihapus (tidak ada batasan jika null atau lebih kecil dari nol).

Contoh

Pertimbangkan tabel CUSTOMER yang memiliki catatan berikut.

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Perintah berikut akan menghapus detail pelanggan, yang ID-nya 6.

DELETE FROM CUSTOMERS WHERE ID = 6;

Setelah menjalankan perintah di atas, periksa tabel Pelanggan dengan menjalankan perintah berikut.

SELECT * FROM CUSTOMERS;

Perintah di atas menghasilkan output berikut -

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  7 | Muffy    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+

Jika kita ingin MENGHAPUS semua record dari tabel CUSTOMERS, kita tidak menggunakan klausa WHERE. Query DELETE adalah sebagai berikut.

DELETE FROM CUSTOMER;

Setelah menjalankan perintah di atas, tidak ada catatan yang akan tersedia di tabel Pelanggan.

BACKUP adalah perintah yang digunakan untuk mengambil backup database ke dalam file .zip terpisah. Objek tidak dikunci, dan ketika dibutuhkan cadangan, log transaksi juga disalin. Hak admin diperlukan untuk menjalankan perintah ini.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Cadangan.

BACKUP TO fileNameString;

Contoh

Dalam contoh ini, mari kita ambil cadangan dari database saat ini ke backup.zipmengajukan. Gunakan perintah berikut untuk hal yang sama.

BACKUP TO 'backup.zip';

Saat menjalankan perintah di atas, Anda akan mendapatkan file backup.zip di sistem file lokal Anda.

CALL adalah perintah SQL yang dimiliki oleh server database H2. Perintah ini digunakan untuk menghitung ekspresi sederhana. Ini mengembalikan hasil dari ekspresi yang diberikan dalam bidang kolom tunggal. Ketika mengembalikan larik hasil, maka setiap elemen dalam larik ditampilkan sebagai nilai kolom.

Sintaksis

Berikut ini adalah sintaks umum dari perintah CALL.

CALL expression;

Kita dapat menggunakan ekspresi aritmatika dalam sintaks ini.

Contoh

Mari kita ambil contoh dan jalankan ekspresi aritmatika (15 * 25) menggunakan perintah panggilan.

CALL 15*25;

Perintah di atas menghasilkan keluaran sebagai berikut.

375
375

MENJELASKAN perintah menampilkan rencana eksekusi untuk sebuah pernyataan. Ketika kita menjalankan pernyataan menggunakan perintah JELASKAN ANALISIS, rencana kueri akan menyertakan jumlah pemindaian baris aktual untuk setiap tabel.

Sintaksis

Berikut ini adalah sintaks umum dari perintah MENJELASKAN.

EXPLAIN { [ PLAN FOR ] | ANALYZE } { select | insert | update | delete | merge}

Bersamaan dengan sintaks ini kita dapat menggunakan pilih, sisipkan, hapus, dan gabungkan.

Contoh

Contoh ini menjelaskan detail paket kueri pelanggan dengan ID 1.

EXPLAIN SELECT * FROM CUSTOMER WHERE ID = 1;

Perintah di atas menghasilkan output berikut -

Perintah MERGE digunakan untuk memperbarui baris yang ada dan memasukkan baris baru ke dalam tabel. Kolom kunci utama memainkan peran penting saat menggunakan perintah ini; ini digunakan untuk mencari baris.

Sintaksis

Berikut ini adalah sintaks umum dari perintah MERGE.

MERGE INTO tableName [ ( columnName [,...] ) ] 
[ KEY ( columnName [,...] ) ] 
{ VALUES { ( { DEFAULT | expression } [,...] ) } [,...] | select }

Dalam sintaks di atas, klausa KEY digunakan untuk menentukan nama kolom kunci utama. Bersama dengan klausa VALUES, kita dapat menggunakan nilai primitif untuk menyisipkan atau kita dapat mengambil dan menyimpan nilai tabel lain ke dalam tabel ini menggunakan perintah pilih.

Contoh

Dalam contoh ini, mari kita coba menambahkan catatan baru ke dalam tabel Pelanggan. Berikut adalah detail dari record baru di tabel.

Nama kolom Nilai
Indo 8
NAMA Lokesh
USIA 32
ALAMAT Hyderabad
GAJI 2500

Dengan menggunakan query berikut, mari kita masukkan record yang diberikan ke query database H2.

MERGE INTO CUSTOMER KEY (ID) VALUES (8, 'Lokesh', 32, 'Hyderabad', 2500);

Kueri di atas menghasilkan keluaran berikut.

Update count: 1

Mari kita verifikasi catatan tabel Pelanggan dengan mengeksekusi query berikut.

SELECT * FROM CUSTOMER;

Kueri di atas menghasilkan keluaran berikut.

Indo Nama Usia Alamat Gaji
1 Ramesh 32 Ahmedabad 2000
2 Khilan 25 Delhi 1500
3 Kaushik 23 Kota 2000
4 Chaitali 25 Mumbai 6500
5 Hardik 27 Bhopal 8500
6 Komal 22 MP 4500
7 Muffy 24 Indore 10000
8 Lokesh 32 Hyderabad 2500

Sekarang mari kita coba perbarui catatan menggunakan Mergeperintah. Berikut rincian record yang akan diupdate.

Nama kolom Nilai
Indo 8
NAMA Loki
USIA 32
ALAMAT Hyderabad
GAJI 3000

Gunakan query berikut untuk memasukkan record yang diberikan ke query database H2.

MERGE INTO CUSTOMER KEY (ID) VALUES (8, 'Loki', 32, 'Hyderabad', 3000);

Kueri di atas menghasilkan keluaran berikut.

Update count: 1

Mari kita verifikasi catatan tabel Pelanggan dengan mengeksekusi query berikut.

SELECT * FROM CUSTOMER;

Kueri di atas menghasilkan keluaran berikut -

Indo Nama Usia Alamat Gaji
1 Ramesh 32 Ahmedabad 2000
2 Khilan 25 Delhi 1500
3 Kaushik 23 Kota 2000
4 Chaitali 25 Mumbai 6500
5 Hardik 27 Bhopal 8500
6 Komal 22 MP 4500
7 Muffy 24 Indore 10000
8 Loki 32 Hyderabad 3000

SHOW adalah perintah yang digunakan untuk menampilkan daftar Skema, Tabel, atau Kolom dari tabel.

Sintaksis

Berikut ini adalah sintaks umum dari perintah SHOW.

SHOW { SCHEMAS | TABLES [ FROM schemaName ] | 
COLUMNS FROM tableName [ FROM schemaName ] }

Contoh

Perintah berikut dapat digunakan untuk mendapatkan daftar tabel di database saat ini.

SHOW TABLES;

Perintah di atas menghasilkan keluaran sebagai berikut.

TABLE_NAME TABLE_SCHEMA
PELANGGAN PUBLIK
EMP PUBLIK

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

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

ALTER adalah perintah yang digunakan untuk mengubah struktur tabel dengan menambahkan klausa yang berbeda ke alterperintah. Berdasarkan skenario, kita perlu menambahkan klausa masing-masing ke perintah alter. Pada bab ini, kita akan membahas berbagai skenario perintah alter.

Ubah Tabel Tambahkan

Alter Table Add adalah perintah yang digunakan untuk menambahkan kolom baru ke tabel bersama dengan tipe datanya masing-masing. Perintah ini melakukan transaksi dalam hubungan ini.

Sintaksis

Berikut ini adalah sintaks generik dari perintah Alter Table Add.

ALTER TABLE [ IF EXISTS ] tableName ADD [ COLUMN ] 
{ [ IF NOT EXISTS ] columnDefinition [ { BEFORE | AFTER } columnName ] 
   | ( { columnDefinition } [,...] ) }

Contoh

Dalam contoh ini, kami akan menambahkan kolom baru start_date Ke meja tutorials_tbl. Jenis data untuk start_date adalah Tanggal. Berikut ini adalah query untuk menambahkan kolom baru.

ALTER TABLE tutorials_tbl ADD start_date DATE;

Kueri di atas menghasilkan keluaran berikut.

(6) rows effected

Ubah Tabel Tambahkan Batasan

Alter table add constraint adalah perintah yang digunakan untuk menambahkan batasan yang berbeda ke tabel seperti primary key, foreign key, bukan null, dll.

Indeks yang diperlukan secara otomatis dibuat jika belum ada. Tidak mungkin menonaktifkan pemeriksaan kendala unik. Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Sintaksis

Berikut ini adalah sintaks generik dari tabel Alter menambahkan perintah batasan.

ALTER TABLE [ IF EXISTS ] tableName ADD constraint [ CHECK | NOCHECK ]

Contoh

Dalam contoh ini, mari kita tambahkan batasan kunci utama (tutorials_tbl_pk) ke kolom id tabel tutorials_tbl, menggunakan kueri berikut.

ALTER TABLE tutorials_tbl ADD CONSTRAINT tutorials_tbl_pk PRIMARYKEY(id);

Kueri di atas menghasilkan keluaran berikut.

(6) row (s) effected

Ubah Batasan Ubah Nama Tabel

Perintah ini digunakan untuk mengganti nama batasan tabel relasi tertentu. Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Alter Table Rename Constraint.

ALTER TABLE [ IF EXISTS ] tableName RENAME oldConstraintName TO newConstraintName

Saat menggunakan sintaks ini, pastikan nama kendala lama harus ada dengan kolom masing-masing.

Contoh

Dalam contoh ini, kami akan mengubah nama kendala kunci utama tabel tutorials_tbl dari tutorials_tbl_pk untuk tutorials_tbl_pk_constraint. Berikut ini adalah pertanyaan untuk melakukannya.

ALTER TABLE tutorials_tbl RENAME CONSTRAINT 
tutorials_tbl_pk TO tutorials_tbl_pk_constraint;

Kueri di atas menghasilkan keluaran berikut.

(1) row (s) effected

Ubah Tabel Mengubah Kolom

Perintah ini digunakan untuk mengubah struktur dan properti kolom tabel tertentu. Mengubah properti berarti mengubah tipe data kolom, mengganti nama kolom, mengubah nilai identitas, atau mengubah selektivitas.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Alter Table Alter Column.

ALTER TABLE [ IF EXISTS ] tableName ALTER COLUMN columnName 
{ { dataType [ DEFAULT expression ] [ [ NOT ] NULL ] [ AUTO_INCREMENT | IDENTITY ] } 
| { RENAME TO name } 
| { RESTART WITH long } 
| { SELECTIVITY int } 
| { SET DEFAULT expression } 
| { SET NULL } 
| { SET NOT NULL } }

Dalam sintaks di atas -

  • RESTART - Perintah mengubah nilai berikutnya dari kolom kenaikan otomatis.

  • SELECTIVITY- Perintah mengatur selektivitas (1-100) untuk kolom. Berdasarkan nilai selektivitas kita dapat mencitrakan nilai kolom.

  • SET DEFAULT - mengubah nilai default kolom.

  • SET NULL - mengatur kolom untuk memungkinkan NULL.

  • SET NOT NULL - mengatur kolom untuk memungkinkan NOT NULL.

Contoh

Dalam contoh ini, kami akan mengganti nama kolom tabel tutorials_tbl dari Title untuk Tutorial_Title menggunakan kueri berikut.

ALTER TABLE tutorials_tbl ALTER COLUMN title RENAME TO tutorial_title;

Kueri di atas menghasilkan keluaran berikut.

(0) row(s) effected

Dengan cara yang sama, kita dapat melakukan skenario berbeda dengan perintah ALTER.

DROP adalah perintah yang diambil dari tata bahasa SQL generik. Perintah ini digunakan untuk menghapus komponen database dan strukturnya dari memori. Ada beberapa skenario berbeda dengan perintah Jatuhkan yang akan kita bahas di bab ini.

Meja Taruh

Drop Table adalah perintah yang menghapus tabel masing-masing dan strukturnya.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Drop Table.

DROP TABLE [ IF EXISTS ] tableName [,...] [ RESTRICT | CASCADE ]

Perintah akan gagal jika kita menggunakan RESTRICT dan tabel yang memiliki tampilan dependen ada. Semua tampilan dependen dihilangkan, saat kita menggunakan kata kunci CASCADE.

Contoh

Dalam contoh ini, kami akan menjatuhkan tabel bernama tes menggunakan kueri berikut.

DROP TABLE test;

Kueri di atas menghasilkan keluaran berikut.

(6) row (s) effected

Jatuhkan Skema

Drop Schema adalah perintah yang menjatuhkan skema masing-masing dari server database. Ini tidak akan berfungsi dari skema saat ini.

Sintaksis

DROP SCHEMA [ IF EXISTS ] schemaName

Contoh

Dalam contoh ini, kami akan menjatuhkan skema bernama test_schema menggunakan kueri berikut.

DROP SCHEMA TEST_SCHEMA;

Kueri di atas menghasilkan keluaran berikut.

(0) row(s) effected

Jatuhkan Urutan

Drop Sequence adalah perintah yang digunakan untuk menjatuhkan urutan dari struktur tabel.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Drop Sequence.

DROP SEQUENCE [ IF EXISTS ] sequenceName

Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Contoh

Dalam contoh ini, kami akan menjatuhkan urutan bernama sequence_id. Berikut adalah perintahnya.

DROP SEQUENCE sequence_id;

Perintah di atas menghasilkan keluaran sebagai berikut.

(0) row (s) effected

Tampilan Drop

Drop View adalah perintah yang digunakan untuk menjatuhkan tampilan yang ada. Semua tampilan dependen juga dihapus jika klausa CASCADE digunakan.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Drop View.

DROP VIEW [ IF EXISTS ] viewName [ RESTRICT | CASCADE ]

Contoh

Dalam contoh ini, kami akan menjatuhkan tampilan bernama sample_view menggunakan kueri berikut.

DROP VIEW sample_view;

Kueri di atas menghasilkan keluaran berikut.

(0) row (s) effected

TRUNCATE adalah perintah yang digunakan untuk menghapus data dari tabel. Tidak seperti DELETE FROM tanpa klausa WHERE, perintah ini tidak dapat dibatalkan. Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Sintaksis

Berikut ini adalah sintaks umum dari perintah truncate.

TRUNCATE TABLE tableName

Contoh

Dalam contoh ini, kami akan memotong tabel bernama test menggunakan kueri berikut.

TRUNCATE TABLE test;

Kueri di atas menghasilkan keluaran berikut.

(6) row (s) effected

COMMIT adalah perintah dari tata bahasa SQL yang digunakan untuk melakukan transaksi. Kami dapat melakukan transaksi tertentu atau kami dapat melakukan transaksi yang sedang dieksekusi.

Sintaksis

Ada dua sintaks berbeda untuk perintah COMMIT.

Berikut ini adalah sintaks umum untuk perintah komit untuk melakukan transaksi saat ini.

COMMIT [ WORK ]

Berikut ini adalah sintaks umum untuk perintah komit untuk melakukan transaksi tertentu.

COMMIT TRANSACTION transactionName

Contoh 1

Dalam contoh ini, mari kita lakukan transaksi saat ini menggunakan perintah berikut.

COMMIT

Perintah di atas menghasilkan keluaran sebagai berikut.

Committed successfully

Contoh 2

Dalam contoh ini, kami akan melakukan transaksi bernama tx_test menggunakan perintah berikut.

COMMIT TRANSACTION tx_test;

Perintah di atas menghasilkan keluaran sebagai berikut.

Committed successfully

Grant adalah perintah yang berasal dari tata bahasa SQL yang digunakan untuk memberikan hak ke tabel, pengguna, atau peran. Hak admin diperlukan untuk menjalankan perintah ini. Perintah ini melakukan transaksi terbuka dalam koneksi ini.

Dalam bab ini, kita akan membahas berbagai skenario perintah Grant.

Berikan Hak

Grant Right adalah perintah untuk memberikan hak admin ke tabel, pengguna, atau peran.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Grant.

GRANT { SELECT | INSERT | UPDATE | DELETE | ALL } [,...] ON 
{ { SCHEMA schemaName } | { tableName [,...] } } 
TO { PUBLIC | userName | roleName }

Contoh

Dalam contoh ini, kami akan memberikan tabel uji sebagai hanya-baca menggunakan perintah berikut.

GRANT SELECT ON TEST TO READONLY

Perintah di atas menghasilkan keluaran sebagai berikut.

Grant successfully

Berikan Alter Skema Apa Pun

Grant Alter Any Schema adalah perintah untuk memberikan hak mengubah skema kepada pengguna masing-masing.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Grant Alter Any Schema.

GRANT ALTER ANY SCHEMA TO userName

Contoh

Dalam contoh ini, kami akan memberikan hak mengubah skema kepada pengguna bernama test_user. Pastikan bahwa test_user ada. Berikut ini adalah kueri untuk memberikan hak istimewa untuk mengubah.

GRANT ALTER ANY SCHEMA TO test_user;

Kueri di atas menghasilkan keluaran berikut.

Granted successfully to test_user

SAVEPOINT adalah perintah yang digunakan untuk menyimpan transaksi sementara. Lebih baik untuk mempertahankan savepoint dalam transaksi Anda karena akan membantu untuk mengembalikan transaksi ke Savepoint masing-masing kapan pun diperlukan.

Sintaksis

Berikut ini adalah sintaks umum dari perintah Savepoint.

SAVEPOINT savepointName

Contoh

Dalam contoh ini, kami akan membuat Savepoint bernama Half_Done menggunakan perintah berikut.

SAVEPOINT Half_Done;

Perintah di atas menghasilkan keluaran sebagai berikut.

Savepoint created

ROLLBACK adalah perintah dari tata bahasa SQL yang digunakan untuk mengembalikan transaksi ke Savepoint atau ke transaksi sebelumnya. Dengan menggunakan perintah ini, kita dapat memutar kembali ke Savepoint tertentu atau kita dapat memutar kembali ke transaksi yang dieksekusi sebelumnya.

Sintaksis

Ada dua sintaks berbeda untuk perintah ROLLABCK.

Berikut ini adalah sintaks umum untuk perintah rollback.

ROLLBACK [ TO SAVEPOINT savepointName ]

Berikut ini adalah sintaks umum dari perintah Rollback ke transaksi tertentu.

ROLLBACK TRANSACTION transactionName

Contoh 1

Dalam contoh ini, kami akan mengembalikan transaksi saat ini ke Savepoint bernama sp1_test menggunakan perintah berikut.

ROLLBACK sp1_test;

Perintah di atas menghasilkan keluaran sebagai berikut.

Rollback successfully

Contoh 2

Dalam contoh berikut, kami akan mengembalikan transaksi lengkap bernama tx_test menggunakan perintah yang diberikan.

ROLLBACK TRANSACTION tx_test;

Perintah di atas menghasilkan keluaran sebagai berikut.

Rollback successfully

H2 adalah database JAVA. Kita dapat berinteraksi dengan database ini dengan menggunakan JDBC. Pada bab ini, kita akan melihat bagaimana membuat koneksi JDBC dengan database H2 dan operasi CRUD dengan database H2.

Secara umum, ada lima langkah untuk membuat koneksi JDBC.

Step 1 - Mendaftarkan driver database JDBC.

Class.forName ("org.h2.Driver");

Step 2 - Membuka koneksi.

Connection conn = DriverManager.getConnection ("jdbc:h2:~/test", "sa","");

Step 3 - Membuat pernyataan.

Statement st = conn.createStatement();

Step 4 - Menjalankan pernyataan dan menerima Resultset.

Stmt.executeUpdate("sql statement");

Step 5 - Menutup koneksi.

conn.close();

Sebelum melanjutkan untuk membuat program lengkap, kita perlu menambahkan h2-1.4.192.jar fileke CLASSPATH. Kita bisa mendapatkan inijar dari folder C:\Program Files (x86)\H2\bin.

Buat tabel

Dalam contoh ini, kami akan menulis program untuk membuat tabel. Pertimbangkan tabel bernamaRegistration memiliki bidang berikut.

S.No Nama kolom Tipe data NOT NULL Kunci utama
1 Indo Jumlah Iya Iya
2 Pertama Varchar (255) Tidak Tidak
3 Terakhir Varchar (255) Tidak Tidak
4 Usia Jumlah Tidak Tidak

Berikut adalah contoh program bernama H2jdbcCreateDemo.

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.SQLException; 
import java.sql.Statement;  

public class H2jdbcCreateDemo { 
   // JDBC driver name and database URL 
   static final String JDBC_DRIVER = "org.h2.Driver";   
   static final String DB_URL = "jdbc:h2:~/test";  
   
   //  Database credentials 
   static final String USER = "sa"; 
   static final String PASS = ""; 
  
   public static void main(String[] args) { 
      Connection conn = null; 
      Statement stmt = null; 
      try { 
         // STEP 1: Register JDBC driver 
         Class.forName(JDBC_DRIVER); 
             
         //STEP 2: Open a connection 
         System.out.println("Connecting to database..."); 
         conn = DriverManager.getConnection(DB_URL,USER,PASS);  
         
         //STEP 3: Execute a query 
         System.out.println("Creating table in given database..."); 
         stmt = conn.createStatement(); 
         String sql =  "CREATE TABLE   REGISTRATION " + 
            "(id INTEGER not NULL, " + 
            " first VARCHAR(255), " +  
            " last VARCHAR(255), " +  
            " age INTEGER, " +  
            " PRIMARY KEY ( id ))";  
         stmt.executeUpdate(sql);
         System.out.println("Created table in given database..."); 
         
         // STEP 4: Clean-up environment 
         stmt.close(); 
         conn.close(); 
      } catch(SQLException se) { 
         //Handle errors for JDBC 
         se.printStackTrace(); 
      } catch(Exception e) { 
         //Handle errors for Class.forName 
         e.printStackTrace(); 
      } finally { 
         //finally block used to close resources 
         try{ 
            if(stmt!=null) stmt.close(); 
         } catch(SQLException se2) { 
         } // nothing we can do 
         try { 
            if(conn!=null) conn.close(); 
         } catch(SQLException se){ 
            se.printStackTrace(); 
         } //end finally try 
      } //end try 
      System.out.println("Goodbye!");
   } 
}

Simpan program di atas ke dalam H2jdbcCreateDemo.java. Kompilasi dan jalankan program di atas dengan menjalankan perintah berikut di command prompt.

\>javac H2jdbcCreateDemo.java 
\>java H2jdbcCreateDemo

Perintah di atas menghasilkan keluaran sebagai berikut.

Connecting to database... 
Creating table in given database... 
Created table in given database... 
Goodbye!

Setelah eksekusi ini, kita dapat memeriksa tabel yang dibuat menggunakan antarmuka H2 SQL.

Sisipkan Rekaman

Dalam contoh ini, kami akan menulis program untuk memasukkan catatan. Mari kita masukkan record berikut ke dalam tabel Registration.

Indo Pertama Terakhir Usia
100 Zara Ali 18
101 Mahnaz Fatma 25
102 Zaid Khan 30
103 Sumit Mital 28

Berikut adalah contoh program bernama H2jdbcInsertDemo.

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.SQLException; 
import java.sql.Statement;  

public class H2jdbcInsertDemo { 
   // JDBC driver name and database URL 
   static final String JDBC_DRIVER = "org.h2.Driver";   
   static final String DB_URL = "jdbc:h2:~/test";  
   
   //  Database credentials 
   static final String USER = "sa"; 
   static final String PASS = ""; 
  
   public static void main(String[] args) { 
      Connection conn = null; 
      Statement stmt = null; 
      try{
         // STEP 1: Register JDBC driver 
         Class.forName(JDBC_DRIVER);  
         
         // STEP 2: Open a connection 
         System.out.println("Connecting to a selected database..."); 
         conn = DriverManager.getConnection(DB_URL,USER,PASS); 
         System.out.println("Connected database successfully..."); 
         
         // STEP 3: Execute a query 
         stmt = conn.createStatement();  
         String sql = "INSERT INTO Registration " + "VALUES (100, 'Zara', 'Ali', 18)"; 
         
         stmt.executeUpdate(sql); 
         sql = "INSERT INTO Registration " + "VALUES (101, 'Mahnaz', 'Fatma', 25)";  
         
         stmt.executeUpdate(sql); 
         sql = "INSERT INTO Registration " + "VALUES (102, 'Zaid', 'Khan', 30)"; 
         
         stmt.executeUpdate(sql); 
         sql = "INSERT INTO Registration " + "VALUES(103, 'Sumit', 'Mittal', 28)"; 
         
         stmt.executeUpdate(sql); 
         System.out.println("Inserted records into the table..."); 
         
         // STEP 4: Clean-up environment 
         stmt.close(); 
         conn.close(); 
      } catch(SQLException se) { 
         // Handle errors for JDBC 
         se.printStackTrace(); 
      } catch(Exception e) { 
         // Handle errors for Class.forName 
         e.printStackTrace(); 
      } finally { 
         // finally block used to close resources 
         try {
            if(stmt!=null) stmt.close();  
         } catch(SQLException se2) { 
         } // nothing we can do 
         try { 
            if(conn!=null) conn.close(); 
         } catch(SQLException se) { 
            se.printStackTrace(); 
         } // end finally try 
      } // end try 
      System.out.println("Goodbye!"); 
   } 
}

Simpan program di atas ke dalam H2jdbcInsertDemo.java. Kompilasi dan jalankan program di atas dengan menjalankan perintah berikut di command prompt.

\>javac H2jdbcInsertDemo.java 
\>java H2jdbcInsertDemo

Perintah di atas menghasilkan keluaran sebagai berikut.

Connecting to a selected database... 
Connected database successfully... 
Inserted records into the table... 
Goodbye!

Baca Rekam

Dalam contoh ini, kami akan menulis program untuk membaca catatan. Mari kita coba membaca semua record dari tabelRegistration.

Berikut adalah contoh program bernama H2jdbcRecordDemo.

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.SQLException; 
import java.sql.Statement;  

public class H2jdbcReadDemo { 
   // JDBC driver name and database URL 
   static final String JDBC_DRIVER = "org.h2.Driver";   
   static final String DB_URL = "jdbc:h2:~/test";  
   
   //  Database credentials 
   static final String USER = "sa"; 
   static final String PASS = ""; 
   
   public static void main(String[] args) { 
      Connection conn = null; 
      Statement stmt = null; 
      try { 
         // STEP 1: Register JDBC driver 
         Class.forName(JDBC_DRIVER); 
         
         // STEP 2: Open a connection 
         System.out.println("Connecting to database..."); 
         conn = DriverManager.getConnection(DB_URL,USER,PASS);  
         
         // STEP 3: Execute a query 
         System.out.println("Connected database successfully..."); 
         stmt = conn.createStatement(); 
         String sql = "SELECT id, first, last, age FROM Registration"; 
         ResultSet rs = stmt.executeQuery(sql); 
         
         // STEP 4: Extract data from result set 
         while(rs.next()) { 
            // Retrieve by column name 
            int id  = rs.getInt("id"); 
            int age = rs.getInt("age"); 
            String first = rs.getString("first"); 
            String last = rs.getString("last");  
            
            // Display values 
            System.out.print("ID: " + id); 
            System.out.print(", Age: " + age); 
            System.out.print(", First: " + first); 
            System.out.println(", Last: " + last); 
         } 
         // STEP 5: Clean-up environment 
         rs.close(); 
      } catch(SQLException se) { 
         // Handle errors for JDBC 
         se.printStackTrace(); 
      } catch(Exception e) { 
         // Handle errors for Class.forName 
         e.printStackTrace(); 
      } finally { 
         // finally block used to close resources 
         try { 
            if(stmt!=null) stmt.close();  
         } catch(SQLException se2) { 
         } // nothing we can do 
         try { 
            if(conn!=null) conn.close(); 
         } catch(SQLException se) { 
            se.printStackTrace(); 
         } // end finally try 
      } // end try 
      System.out.println("Goodbye!"); 
   } 
}

Simpan program di atas ke dalam H2jdbcReadDemo.java. Kompilasi dan jalankan program di atas dengan menjalankan perintah berikut di command prompt.

\>javac H2jdbcReadDemo.java 
\>java H2jdbcReadDemo

Perintah di atas menghasilkan keluaran sebagai berikut.

Connecting to a selected database... 
Connected database successfully... 
ID: 100, Age: 18, First: Zara, Last: Ali 
ID: 101, Age: 25, First: Mahnaz, Last: Fatma 
ID: 102, Age: 30, First: Zaid, Last: Khan 
ID: 103, Age: 28, First: Sumit, Last: Mittal 
Goodbye!

Perbarui Rekaman

Dalam contoh ini, kami akan menulis program untuk memperbarui catatan. Mari kita coba membaca semua record dari tabelRegistration.

Berikut adalah contoh program bernama H2jdbcUpdateDemo.

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.SQLException; 
import java.sql.Statement;  

public class H2jdbcUpdateDemo { 
   // JDBC driver name and database URL 
   static final String JDBC_DRIVER = "org.h2.Driver";   
   static final String DB_URL = "jdbc:h2:~/test";  
   
   // Database credentials 
   static final String USER = "sa"; 
   static final String PASS = ""; 
   
   public static void main(String[] args) { 
      Connection conn = null; 
      Statement stmt = null; 
      try { 
         // STEP 1: Register JDBC driver 
         Class.forName(JDBC_DRIVER); 
         
         // STEP 2: Open a connection 
         System.out.println("Connecting to a database..."); 
         conn = DriverManager.getConnection(DB_URL,USER,PASS);  
         
         // STEP 3: Execute a query 
         System.out.println("Connected database successfully..."); 
         stmt = conn.createStatement(); 
         String sql = "UPDATE Registration " + "SET age = 30 WHERE id in (100, 101)"; 
         stmt.executeUpdate(sql);  
         
         // Now you can extract all the records 
         // to see the updated records 
         sql = "SELECT id, first, last, age FROM Registration"; 
         ResultSet rs = stmt.executeQuery(sql);  
         
         while(rs.next()){ 
            // Retrieve by column name 
            int id  = rs.getInt("id"); 
            int age = rs.getInt("age"); 
            String first = rs.getString("first"); 
            String last = rs.getString("last");  
            
            // Display values 
            System.out.print("ID: " + id); 
            System.out.print(", Age: " + age); 
            System.out.print(", First: " + first); 
            System.out.println(", Last: " + last); 
         } 
         rs.close();    
      } catch(SQLException se) { 
         // Handle errors for JDBC 
         se.printStackTrace(); 
      } catch(Exception e) { 
         // Handle errors for Class.forName 
         e.printStackTrace(); 
      } finally { 
         // finally block used to close resources  
         try { 
            if(stmt!=null) stmt.close(); 
         } catch(SQLException se2) { 
         } // nothing we can do 
         try { 
            if(conn!=null) conn.close(); 
         } catch(SQLException se) { 
            se.printStackTrace(); 
         } // end finally try 
      } // end try 
      System.out.println("Goodbye!"); 
   } 
}

Simpan program di atas ke dalam H2jdbcUpdateDemo.java. Kompilasi dan jalankan program di atas dengan menjalankan perintah berikut di command prompt.

\>javac H2jdbcUpdateDemo.java 
\>java H2jdbcUpdateDemo

Perintah di atas menghasilkan keluaran sebagai berikut.

Connecting to a selected database... 
Connected database successfully... 
ID: 100, Age: 30, First: Zara, Last: Ali 
ID: 101, Age: 30, First: Mahnaz, Last: Fatma 
ID: 102, Age: 30, First: Zaid, Last: Khan 
ID: 103, Age: 28, First: Sumit, Last: Mittal 
Goodbye!

Hapus Rekaman

Dalam contoh ini, kami akan menulis program untuk menghapus catatan. Mari kita coba membaca semua record dari tabelRegistration.

Berikut adalah contoh program bernama H2jdbcDeleteDemo.

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.ResultSet; 
import java.sql.SQLException; 
import java.sql.Statement;  

public class H2jdbcDeleteDemo { 
   // JDBC driver name and database URL 
   static final String JDBC_DRIVER = "org.h2.Driver";   
   static final String DB_URL = "jdbc:h2:~/test";  
   
   // Database credentials 
   static final String USER = "sa"; 
   static final String PASS = ""; 
  
   public static void main(String[] args) { 
      Connection conn = null; 
      Statement stmt = null; 
      try { 
         // STEP 1: Register JDBC driver 
         Class.forName(JDBC_DRIVER);  
         
         // STEP 2: Open a connection 
         System.out.println("Connecting to database..."); 
         conn = DriverManager.getConnection(DB_URL,USER,PASS);  
         
         // STEP 3: Execute a query
         System.out.println("Creating table in given database..."); 
         stmt = conn.createStatement();  
         String sql = "DELETE FROM Registration " + "WHERE id = 101"; 
         stmt.executeUpdate(sql);  
         
         // Now you can extract all the records 
         // to see the remaining records 
         sql = "SELECT id, first, last, age FROM Registration"; 
         ResultSet rs = stmt.executeQuery(sql);  
         
         while(rs.next()){ 
            // Retrieve by column name 
            int id  = rs.getInt("id"); 
            int age = rs.getInt("age"); 
            String first = rs.getString("first"); 
            String last = rs.getString("last");  
            
            // Display values 
            System.out.print("ID: " + id); 
            System.out.print(", Age: " + age); 
            System.out.print(", First: " + first); 
            System.out.println(", Last: " + last); 
         } 
         rs.close(); 
      } catch(SQLException se) { 
         // Handle errors for JDBC 
         se.printStackTrace();  
      } catch(Exception e) { 
         // Handle errors for Class.forName 
         e.printStackTrace(); 
      } finally { 
         // finally block used to close resources 
         try { 
            if(stmt!=null) stmt.close(); 
         } catch(SQLException se2) { 
         } // nothing we can do 
         try { 
            if(conn!=null) conn.close(); 
         } catch(SQLException se) { 
            se.printStackTrace(); 
         } // end finally try
      } // end try 
      System.out.println("Goodbye!"); 
   } 
}

Simpan program di atas ke dalam H2jdbcDeleteDemo.java. Kompilasi dan jalankan program di atas dengan menjalankan perintah berikut di command prompt.

\>javac H2jdbcDeleteDemo.java 
\>java H2jdbcDeleteDemo

Perintah di atas menghasilkan keluaran sebagai berikut.

Connecting to a selected database... 
Connected database successfully... 
ID: 100, Age: 30, First: Zara, Last: Ali 
ID: 102, Age: 30, First: Zaid, Last: Khan 
ID: 103, Age: 28, First: Sumit, Last: Mittal 
Goodbye!