JDBC - Panduan Cepat
Apa itu JDBC?
JDBC adalah singkatan dari Java Database Connectivity, yang merupakan Java API standar untuk konektivitas independen database antara bahasa pemrograman Java dan berbagai database.
Pustaka JDBC menyertakan API untuk setiap tugas yang umumnya terkait dengan penggunaan database:
Membuat koneksi ke database
Membuat pernyataan SQL atau MySQL
Mengeksekusi kueri SQL atau MySQL itu di database
Melihat & Memodifikasi rekaman yang dihasilkan
Prasyarat:
Anda harus memiliki pemahaman yang baik tentang dua mata pelajaran berikut untuk mempelajari JDBC:
Pemrograman JAWA Inti
Database SQL atau MySQL
JDBC - Pengaturan Lingkungan:
Pastikan Anda telah melakukan penyiapan berikut:
Instalasi Core JAVA
Instalasi SQL atau Database MySQL
Terlepas dari hal di atas, Anda perlu mengatur database yang akan Anda gunakan untuk proyek Anda. Dengan asumsi ini adalah EMP dan Anda telah membuat Karyawan di tabel dalam database yang sama.
Membuat Aplikasi JDBC:
Ada enam langkah yang terlibat dalam membangun aplikasi JDBC yang akan saya jelaskan dalam tutorial ini:
Impor paket:
Ini mengharuskan Anda menyertakan paket yang berisi kelas JDBC yang diperlukan untuk pemrograman database. Paling sering, menggunakan import java.sql. * Sudah cukup sebagai berikut:
//STEP 1. Import required packages
import java.sql.*;
Daftarkan driver JDBC:
Ini mengharuskan Anda menginisialisasi driver sehingga Anda dapat membuka saluran komunikasi dengan database. Berikut adalah potongan kode untuk mencapai ini:
//STEP 2: Register JDBC driver
Class.forName("com.mysql.jdbc.Driver");
Buka koneksi:
Ini memerlukan penggunaan metode DriverManager.getConnection () untuk membuat objek Connection, yang mewakili koneksi fisik dengan database sebagai berikut:
//STEP 3: Open a connection
// Database credentials
static final String USER = "username";
static final String PASS = "password";
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
Jalankan kueri:
Ini membutuhkan penggunaan objek tipe Pernyataan atau PreparedStatement untuk membangun dan mengirimkan pernyataan SQL ke database sebagai berikut:
//STEP 4: Execute a query
System.out.println("Creating statement...");
stmt = conn.createStatement();
String sql;
sql = "SELECT id, first, last, age FROM Employees";
ResultSet rs = stmt.executeQuery(sql);
Jika ada pernyataan SQL UPDATE, INSERT atau DELETE diperlukan, maka cuplikan kode berikut akan diperlukan:
//STEP 4: Execute a query
System.out.println("Creating statement...");
stmt = conn.createStatement();
String sql;
sql = "DELETE FROM Employees";
ResultSet rs = stmt.executeUpdate(sql);
Ekstrak data dari kumpulan hasil:
Langkah ini diperlukan jika Anda mengambil data dari database. Anda bisa menggunakan metode ResultSet.getXXX () yang sesuai untuk mengambil data dari set hasil sebagai berikut:
//STEP 5: 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);
}
Bersihkan lingkungan:
Anda harus menutup semua sumber daya database secara eksplisit versus mengandalkan pengumpulan sampah JVM sebagai berikut:
//STEP 6: Clean-up environment
rs.close();
stmt.close();
conn.close();
Program JDBC Pertama:
Berdasarkan langkah-langkah di atas, kita dapat memiliki kode sampel gabungan yang dapat kita gunakan sebagai template saat menulis kode JDBC kita:
Kode contoh ini telah ditulis berdasarkan lingkungan dan pengaturan database dilakukan di bab Lingkungan.
//STEP 1. Import required packages
import java.sql.*;
public class FirstExample {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost/EMP";
// Database credentials
static final String USER = "username";
static final String PASS = "password";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try{
//STEP 2: Register JDBC driver
Class.forName("com.mysql.jdbc.Driver");
//STEP 3: Open a connection
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
//STEP 4: Execute a query
System.out.println("Creating statement...");
stmt = conn.createStatement();
String sql;
sql = "SELECT id, first, last, age FROM Employees";
ResultSet rs = stmt.executeQuery(sql);
//STEP 5: 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 6: Clean-up environment
rs.close();
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!");
}//end main
}//end FirstExample
Sekarang mari kita kompilasi contoh di atas sebagai berikut:
C:\>javac FirstExample.java
C:\>
Saat kamu lari FirstExample, itu menghasilkan hasil sebagai berikut:
C:\>java FirstExample
Connecting to database...
Creating statement...
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
C:\>
Metode SQLException:
SQLException dapat terjadi di driver dan database. Ketika pengecualian seperti itu terjadi, objek tipe SQLException akan diteruskan ke klausa catch.
Objek SQLException yang diteruskan memiliki metode berikut ini yang tersedia untuk mengambil informasi tambahan tentang pengecualian:
metode | Deskripsi |
---|---|
getErrorCode () | Mendapat nomor kesalahan yang terkait dengan pengecualian. |
getMessage () | Mendapat pesan kesalahan driver JDBC untuk kesalahan yang ditangani oleh driver atau mendapatkan nomor dan pesan kesalahan Oracle untuk kesalahan database. |
getSQLState () | Mendapat string XOPEN SQLstate. Untuk kesalahan driver JDBC, tidak ada informasi berguna yang dikembalikan dari metode ini. Untuk kesalahan database, kode XOPEN SQLstate lima digit dikembalikan. Metode ini dapat mengembalikan null. |
getNextException () | Mengambil objek Exception berikutnya dalam rantai pengecualian. |
printStackTrace () | Mencetak pengecualian saat ini, atau throwable, dan pelacakan baliknya ke aliran kesalahan standar. |
printStackTrace (PrintStream s) | Mencetak lemparan ini dan lacak baliknya ke aliran cetak yang Anda tentukan. |
printStackTrace (PrintWriter w) | Mencetak throwable ini dan lacak baliknya ke penulis cetak yang Anda tentukan. |
Dengan memanfaatkan informasi yang tersedia dari objek Exception, Anda dapat menangkap pengecualian dan melanjutkan program Anda dengan tepat. Berikut adalah bentuk umum dari blok percobaan:
try {
// Your risky code goes between these curly braces!!!
}
catch(Exception ex) {
// Your exception handling code goes between these
// curly braces, similar to the exception clause
// in a PL/SQL block.
}
finally {
// Your must-always-be-executed code goes between these
// curly braces. Like closing database connection.
}
JDBC - Tipe Data:
Tabel berikut merangkum tipe data JDBC default yang menjadi tipe data Java saat Anda memanggil metode setXXX () dari objek PreparedStatement atau CallableStatement atau metode ResultSet.updateXXX ().
SQL | JDBC / Java | setXXX | updateXXX |
---|---|---|---|
VARCHAR | java.lang.String | setString | updateString |
ARANG | java.lang.String | setString | updateString |
LONGVARCHAR | java.lang.String | setString | updateString |
SEDIKIT | boolean | setBoolean | updateBoolean |
NUMERIK | java.math.BigDecimal | setBigDecimal | updateBigDecimal |
TINYINT | byte | setByte | updateByte |
SMALLINT | pendek | setShort | updateShort |
BILANGAN BULAT | int | setInt | updateInt |
BIGINT | panjang | setLong | updateLong |
NYATA | mengapung | setFloat | updateFloat |
MENGAPUNG | mengapung | setFloat | updateFloat |
DUA KALI LIPAT | dua kali lipat | setDouble | updateDouble |
VARBINER | byte [] | setBytes | updateBytes |
BINER | byte [] | setBytes | updateBytes |
TANGGAL | java.sql.Date | Atur tanggal | updateDate |
WAKTU | java.sql.Time | Atur waktu | updateTime |
TIMESTAMP | java.sql.Timestamp | setTimestamp | updateTimestamp |
CLOB | java.sql.Clob | setClob | updateClob |
GUMPAL | java.sql.Blob | setBlob | updateBlob |
HIMPUNAN | java.sql.Array | setARRAY | updateARRAY |
REF | java.sql.Ref | SetRef | updateRef |
STRUKT | java.sql.Struct | SetStruct | updateStruct |
JDBC 3.0 telah meningkatkan dukungan untuk tipe data BLOB, CLOB, ARRAY, dan REF. Objek ResultSet sekarang memiliki metode updateBLOB (), updateCLOB (), updateArray (), dan updateRef () yang memungkinkan Anda memanipulasi data terkait secara langsung di server.
Metode setXXX () dan updateXXX () memungkinkan Anda untuk mengonversi tipe Java tertentu ke tipe data JDBC tertentu. Metode, setObject () dan updateObject (), memungkinkan Anda untuk memetakan hampir semua tipe Java ke tipe data JDBC.
Objek ResultSet menyediakan metode getXXX () yang sesuai untuk setiap tipe data untuk mengambil nilai kolom. Setiap metode dapat digunakan dengan nama kolom atau dengan posisi ordinalnya.
SQL | JDBC / Java | setXXX | getXXX |
---|---|---|---|
VARCHAR | java.lang.String | setString | getString |
ARANG | java.lang.String | setString | getString |
LONGVARCHAR | java.lang.String | setString | getString |
SEDIKIT | boolean | setBoolean | getBoolean |
NUMERIK | java.math.BigDecimal | setBigDecimal | getBigDecimal |
TINYINT | byte | setByte | getByte |
SMALLINT | pendek | setShort | getShort |
BILANGAN BULAT | int | setInt | getInt |
BIGINT | panjang | setLong | getLong |
NYATA | mengapung | setFloat | getFloat |
MENGAPUNG | mengapung | setFloat | getFloat |
DUA KALI LIPAT | dua kali lipat | setDouble | getDouble |
VARBINER | byte [] | setBytes | getBytes |
BINER | byte [] | setBytes | getBytes |
TANGGAL | java.sql.Date | Atur tanggal | getDate |
WAKTU | java.sql.Time | Atur waktu | getTime |
TIMESTAMP | java.sql.Timestamp | setTimestamp | getTimestamp |
CLOB | java.sql.Clob | setClob | getClob |
GUMPAL | java.sql.Blob | setBlob | getBlob |
HIMPUNAN | java.sql.Array | setARRAY | getARRAY |
REF | java.sql.Ref | SetRef | getRef |
STRUKT | java.sql.Struct | SetStruct | getStruct |
JDBC - Pemrosesan Batch:
Pemrosesan Batch memungkinkan Anda untuk mengelompokkan pernyataan SQL terkait ke dalam batch dan mengirimkannya dengan satu panggilan ke database.
Saat Anda mengirim beberapa pernyataan SQL ke database sekaligus, Anda mengurangi jumlah overhead komunikasi, sehingga meningkatkan kinerja.
Driver JDBC tidak diperlukan untuk mendukung fitur ini. Anda harus menggunakan metode DatabaseMetaData.supportsBatchUpdates () untuk menentukan apakah database target mendukung pemrosesan pembaruan batch. Metode ini mengembalikan nilai true jika driver JDBC Anda mendukung fitur ini.
Itu addBatch()metode Statement, PreparedStatement, dan CallableStatement digunakan untuk menambahkan pernyataan individual ke batch. ItuexecuteBatch() digunakan untuk memulai eksekusi semua pernyataan yang dikelompokkan bersama.
Itu executeBatch() mengembalikan larik bilangan bulat, dan setiap elemen larik mewakili jumlah pembaruan untuk pernyataan pembaruan masing-masing.
Sama seperti Anda dapat menambahkan pernyataan ke kelompok untuk diproses, Anda juga dapat menghapusnya dengan clearBatch()metode. Metode ini menghapus semua pernyataan yang Anda tambahkan dengan metode addBatch (). Namun, Anda tidak dapat memilih pernyataan mana yang akan dihapus secara selektif.
JDBC - Data Streaming:
Objek PreparedStatement memiliki kemampuan untuk menggunakan aliran input dan output untuk menyediakan data parameter. Ini memungkinkan Anda untuk menempatkan seluruh file ke dalam kolom database yang dapat menampung nilai-nilai besar, seperti tipe data CLOB dan BLOB.
Ada beberapa metode berikut yang dapat digunakan untuk mengalirkan data:
setAsciiStream(): Metode ini digunakan untuk memberikan nilai ASCII yang besar.
setCharacterStream(): Metode ini digunakan untuk memberikan nilai UNICODE yang besar.
setBinaryStream(): Metode ini digunakan untuk memberikan nilai biner yang besar.
Metode setXXXStream () memerlukan parameter tambahan, ukuran file, selain placeholder parameter. Parameter ini memberi tahu pengemudi berapa banyak data yang harus dikirim ke database menggunakan aliran.
Untuk detail tentang semua konsep ini, Anda harus melalui tutorial lengkap.