JDBC - Contoh, Kode Contoh

Bab ini memberikan contoh cara membuat aplikasi JDBC sederhana. Ini akan menunjukkan kepada Anda cara membuka koneksi database, menjalankan kueri SQL, dan menampilkan hasilnya.

Semua langkah yang disebutkan dalam contoh templat ini, akan dijelaskan pada bab-bab selanjutnya dari tutorial ini.

Membuat Aplikasi JDBC

Ada enam langkah berikut yang terlibat dalam membangun aplikasi JDBC -

  • Import the packages:Mengharuskan Anda menyertakan paket yang berisi kelas JDBC yang diperlukan untuk pemrograman database. Paling sering, menggunakan import java.sql. * Sudah cukup.

  • Register the JDBC driver: Mengharuskan Anda menginisialisasi driver sehingga Anda bisa membuka saluran komunikasi dengan database.

  • Open a connection:Memerlukan penggunaan metode DriverManager.getConnection () untuk membuat objek Connection, yang mewakili koneksi fisik dengan database.

  • Execute a query: Memerlukan penggunaan objek Pernyataan tipe untuk membangun dan mengirimkan pernyataan SQL ke database.

  • Extract data from result set:Mengharuskan Anda menggunakan metode ResultSet.getXXX () yang sesuai untuk mengambil data dari kumpulan hasil.

  • Clean up the environment: Mengharuskan menutup semua sumber daya database secara eksplisit versus mengandalkan pengumpulan sampah JVM.

Kode sampel

Contoh contoh ini dapat berfungsi sebagai template saat Anda perlu membuat aplikasi JDBC Anda sendiri di masa mendatang.

Kode contoh ini telah ditulis berdasarkan lingkungan dan penyiapan database yang dilakukan di bab sebelumnya.

Salin dan tempel contoh berikut di FirstExample.java, kompilasi dan jalankan seperti berikut -

//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:\>