Antarmuka ResultSetHandler

Itu org.apache.commons.dbutils.ResultSetHandler antarmuka bertanggung jawab untuk mengubah ResultSets menjadi objek.

Deklarasi Kelas

Berikut adalah deklarasi untuk kelas org.apache.commons.dbutils.ResultSetHandler -

public interface ResultSetHandler<T>

Pemakaian

  • Step 1 - Buat objek koneksi.

  • Step 2 - Membuat implementasi ResultSetHandler.

  • Step 3 - Meneruskan resultSetHandler ke objek QueryRunner, dan melakukan operasi database.

Contoh

Contoh berikut akan mendemonstrasikan cara memetakan record menggunakan kelas ResultSetHandler. Kami akan membaca salah satu catatan yang tersedia di Tabel Karyawan.

Sintaksis

Employee emp = queryRunner.query(conn, "SELECT * FROM employees WHERE first=?", resultHandler, "Sumit");

Dimana,

  • resultHandler - Objek ResultSetHandler untuk memetakan hasil yang disetel ke objek Karyawan.

  • queryRunner - Objek QueryRunner untuk membaca objek karyawan dari database.

Untuk memahami konsep yang disebutkan di atas terkait dengan DBUtils, mari kita tulis contoh yang akan menjalankan kueri baca. Untuk menulis contoh kita, mari kita buat aplikasi contoh.

Langkah Deskripsi
1 Perbarui file MainApp.java yang dibuat di bawah bab DBUtils - Aplikasi Pertama .
2 Kompilasi dan jalankan aplikasi seperti yang dijelaskan di bawah ini.

Berikut ini adalah konten dari Employee.java.

public class Employee {
   private int id;
   private int age;
   private String first;
   private String last;
   public int getId() {
      return id;
   }
   public void setId(int id) {
      this.id = id;
   }
   public int getAge() {
      return age;
   }
   public void setAge(int age) {
      this.age = age;
   }
   public String getFirst() {
      return first;
   }
   public void setFirst(String first) {
      this.first = first;
   }
   public String getLast() {
      return last;
   }
   public void setLast(String last) {
      this.last = last;
   }
}

Berikut ini adalah konten dari MainApp.java mengajukan.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.util.Arrays;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;

public class MainApp {
   // JDBC driver name and database URL
   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
   static final String DB_URL = "jdbc:mysql://localhost:3306/emp";

   //  Database credentials
   static final String USER = "root";
   static final String PASS = "admin";

   public static void main(String[] args) throws SQLException {
      Connection conn = null;
      QueryRunner queryRunner = new QueryRunner();
      
      //Step 1: Register JDBC driver
      DbUtils.loadDriver(JDBC_DRIVER);

      //Step 2: Open a connection
      System.out.println("Connecting to database...");
      conn = DriverManager.getConnection(DB_URL, USER, PASS);

      //Step 3: Create a ResultSet Handler to handle Employee Beans
      ResultSetHandler<Object[]> handler = new ResultSetHandler<Object[]>() {
         public Object[] handle(ResultSet rs) throws SQLException {
            if (!rs.next()) {
               return null;
            }
            ResultSetMetaData meta = rs.getMetaData();
            int cols = meta.getColumnCount();
            Object[] result = new Object[cols];

            for (int i = 0; i < cols; i++) {
               result[i] = rs.getObject(i + 1);
            }
            return result;
         }
      };

      try {
         Object[] result  = queryRunner.query(conn, "SELECT * FROM employees WHERE id=?",
            handler, 103);
         //Display values
         System.out.print("Result: " + Arrays.toString(result));            
      } finally {
         DbUtils.close(conn);
      }              
   }
}

Setelah Anda selesai membuat file sumber, biarkan kami menjalankan aplikasinya. Jika semuanya baik-baik saja dengan aplikasi Anda, itu akan mencetak pesan berikut.

Connecting to database...
Result: [103, 33, Sumit, Mittal]