Apache Commons DBUtils - คู่มือฉบับย่อ

ไลบรารี Apache Commons DbUtils เป็นชุดคลาสที่ค่อนข้างเล็กซึ่งออกแบบมาเพื่อให้การประมวลผลการโทร JDBC ง่ายขึ้นโดยไม่มีการรั่วไหลของทรัพยากรและมีโค้ดที่สะอาดกว่า เนื่องจากการล้างทรัพยากร JDBC ค่อนข้างน่าเบื่อและเกิดข้อผิดพลาดได้ง่ายคลาส DBUtils จึงช่วยแยกโค้ดของแผ่นบอยเลอร์เพลทเพื่อให้นักพัฒนาสามารถมุ่งเน้นไปที่การดำเนินการที่เกี่ยวข้องกับฐานข้อมูลเท่านั้น

ข้อดีของ DBUtils

ข้อดีของการใช้ Apache Commons DBUtils มีอธิบายไว้ด้านล่าง -

  • No Resource Leakage - คลาส DBUtils ช่วยให้มั่นใจได้ว่าจะไม่มีการรั่วไหลของทรัพยากร

  • Clean & Clear code - คลาส DBUtils จัดเตรียมโค้ดที่สะอาดและชัดเจนเพื่อดำเนินการฐานข้อมูลโดยไม่จำเป็นต้องเขียนการล้างข้อมูลหรือรหัสป้องกันการรั่วไหลของทรัพยากร

  • Bean Mapping - คลาส DBUtils รองรับการเติมข้อมูล javabeans โดยอัตโนมัติจากชุดผลลัพธ์

หลักการออกแบบ DBUtils

หลักการออกแบบ Apache Commons DBUtils มีดังนี้ -

  • Small - ไลบรารี DBUtils มีขนาดเล็กมากและมีคลาสน้อยกว่าเพื่อให้เข้าใจและใช้งานได้ง่าย

  • Transparent- ห้องสมุด DBUtils ไม่ได้ทำงานเบื้องหลังมากนัก ใช้เวลาเพียงแค่สอบถามและดำเนินการ

  • Fast - คลาสไลบรารี DBUtils ไม่สร้างวัตถุพื้นหลังจำนวนมากและค่อนข้างรวดเร็วในการดำเนินการฐานข้อมูล

ในการเริ่มต้นการพัฒนาด้วย DBUtils คุณควรตั้งค่าสภาพแวดล้อม DBUtils ของคุณโดยทำตามขั้นตอนที่แสดงด้านล่าง เราถือว่าคุณกำลังทำงานบนแพลตฟอร์ม Windows

ติดตั้ง Java

ติดตั้ง J2SE 5.0 Development Kit (JDK 5.0) จากJava เว็บไซต์อย่างเป็นทางการ

ตรวจสอบให้แน่ใจว่าได้ตั้งค่าตัวแปรสภาพแวดล้อมตามที่อธิบายไว้ด้านล่าง -

  • JAVA_HOME - ตัวแปรสภาพแวดล้อมนี้ควรชี้ไปที่ไดเร็กทอรีที่คุณติดตั้ง JDK เช่น C: \ Program Files \ Java \ jdk1.5.0

  • CLASSPATH - ตัวแปรสภาพแวดล้อมนี้ควรมีการกำหนดเส้นทางที่เหมาะสมเช่น C: \ Program Files \ Java \ jdk1.5.0_20 \ jre \ lib

  • PATH - ตัวแปรสภาพแวดล้อมนี้ควรชี้ไปที่ถัง JRE ที่เหมาะสมเช่น C: \ Program Files \ Java \ jre1.5.0_20 \ bin

เป็นไปได้ว่าคุณตั้งค่าตัวแปรเหล่านี้ไว้แล้ว แต่เพื่อให้แน่ใจว่านี่คือวิธีตรวจสอบ

  • ไปที่แผงควบคุมและดับเบิลคลิกที่ระบบ หากคุณเป็นผู้ใช้ Windows XP คุณต้องเปิด Performance and Maintenance ก่อนจึงจะเห็นไอคอน System

  • ไปที่แท็บขั้นสูงและคลิกที่ตัวแปรสภาพแวดล้อม

  • ตรวจสอบว่าตัวแปรที่กล่าวถึงข้างต้นทั้งหมดได้รับการตั้งค่าอย่างถูกต้องหรือไม่

ติดตั้งฐานข้อมูล

สิ่งที่สำคัญที่สุดที่คุณต้องการแน่นอนคือฐานข้อมูลที่ใช้งานจริงพร้อมตารางที่คุณสามารถสอบถามและแก้ไขได้

ติดตั้งฐานข้อมูลที่เหมาะสมที่สุดสำหรับคุณ คุณสามารถมีทางเลือกมากมายและที่พบบ่อยที่สุดคือ -

  • MySQL DB:MySQL เป็นฐานข้อมูลโอเพ่นซอร์ส คุณสามารถดาวน์โหลดได้จากMySQL เว็บไซต์อย่างเป็นทางการ ขอแนะนำให้ดาวน์โหลดการติดตั้ง Windows แบบเต็ม

    นอกจากนี้การดาวน์โหลดและติดตั้งMySQL ผู้ดูแลเช่นเดียวกับเบราว์เซอร์ MySQL Query นี่คือเครื่องมือที่ใช้ GUI ซึ่งจะทำให้การพัฒนาของคุณง่ายขึ้นมาก

    สุดท้ายดาวน์โหลดและคลายซิปMySQL Connector / J (ไดรเวอร์ MySQL JDBC) ในไดเร็กทอรีที่สะดวก สำหรับจุดประสงค์ของบทช่วยสอนนี้เราจะถือว่าคุณได้ติดตั้งไดรเวอร์ไว้ที่ C: \ Program Files \ MySQL \ mysql-connector-java-5.1.8

    ดังนั้นตั้งค่าตัวแปร CLASSPATH เป็น C: \ Program Files \ MySQL \ mysql-connector-java-5.1.8 \ mysql-connector-java-5.1.8-bin.jar เวอร์ชันไดรเวอร์ของคุณอาจแตกต่างกันไปตามการติดตั้งของคุณ

  • PostgreSQL DB:PostgreSQL เป็นฐานข้อมูลโอเพ่นซอร์ส คุณสามารถดาวน์โหลดได้จากPostgreSQL เว็บไซต์อย่างเป็นทางการ

    การติดตั้ง Postgres ประกอบด้วยเครื่องมือการดูแลระบบที่ใช้ GUI ที่เรียกว่า pgAdmin III ไดรเวอร์ JDBC รวมอยู่ด้วยเป็นส่วนหนึ่งของการติดตั้ง

  • Oracle DB- Oracle DB เป็นฐานข้อมูลเชิงพาณิชย์ที่จำหน่ายโดย Oracle เราถือว่าคุณมีสื่อแจกจ่ายที่จำเป็นในการติดตั้ง

    การติดตั้ง Oracle มีเครื่องมือการดูแลระบบที่ใช้ GUI ที่เรียกว่า Enterprise Manager ไดรเวอร์ JDBC รวมอยู่ด้วยเป็นส่วนหนึ่งของการติดตั้ง

ติดตั้งไดรเวอร์ฐานข้อมูล

JDK ล่าสุดมีไดรเวอร์ JDBC-ODBC Bridge ที่ทำให้ไดรเวอร์ Open Database Connectivity (ODBC) ส่วนใหญ่พร้อมใช้งานสำหรับโปรแกรมเมอร์ที่ใช้ JDBC API

ปัจจุบันผู้จำหน่ายฐานข้อมูลส่วนใหญ่จัดหาไดรเวอร์ JDBC ที่เหมาะสมพร้อมกับการติดตั้งฐานข้อมูล ดังนั้นคุณไม่ควรกังวลเกี่ยวกับส่วนนี้

ตั้งค่าฐานข้อมูลรับรอง

สำหรับบทช่วยสอนนี้เราจะใช้ฐานข้อมูล MySQL เมื่อคุณติดตั้งฐานข้อมูลใด ๆ ข้างต้น ID ผู้ดูแลระบบจะถูกตั้งค่าเป็นroot และให้ข้อกำหนดในการตั้งรหัสผ่านที่คุณเลือก

การใช้ root ID และรหัสผ่านคุณสามารถสร้าง ID ผู้ใช้และรหัสผ่านอื่นหรือคุณสามารถใช้ root ID และรหัสผ่านสำหรับแอปพลิเคชัน JDBC ของคุณ

มีการดำเนินการฐานข้อมูลต่างๆเช่นการสร้างและการลบฐานข้อมูลซึ่งจะต้องใช้ ID ผู้ดูแลระบบและรหัสผ่าน

สำหรับบทช่วยสอน JDBC ที่เหลือเราจะใช้ฐานข้อมูล MySQL กับ username เป็น ID และ password เป็นรหัสผ่าน

หากคุณไม่มีสิทธิ์เพียงพอในการสร้างผู้ใช้ใหม่คุณสามารถขอให้ผู้ดูแลระบบฐานข้อมูล (DBA) สร้าง ID ผู้ใช้และรหัสผ่านให้คุณได้

สร้างฐานข้อมูล

เพื่อสร้างไฟล์ emp ฐานข้อมูลใช้ขั้นตอนต่อไปนี้ -

ขั้นตอนที่ 1

เปิดไฟล์ Command Prompt และเปลี่ยนเป็นไดเร็กทอรีการติดตั้งดังนี้ -

C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>

Note: เส้นทางไป mysqld.exeอาจแตกต่างกันไปขึ้นอยู่กับตำแหน่งการติดตั้ง MySQL บนระบบของคุณ คุณยังสามารถตรวจสอบเอกสารเกี่ยวกับวิธีเริ่มและหยุดเซิร์ฟเวอร์ฐานข้อมูลของคุณ

ขั้นตอนที่ 2

เริ่มต้นเซิร์ฟเวอร์ฐานข้อมูลโดยดำเนินการคำสั่งต่อไปนี้หากยังไม่ได้รัน

C:\Program Files\MySQL\bin>mysqld
C:\Program Files\MySQL\bin>

ขั้นตอนที่ 3

สร้างไฟล์ emp ฐานข้อมูลโดยดำเนินการคำสั่งต่อไปนี้ -

C:\Program Files\MySQL\bin> mysqladmin create emp -u root -p
Enter password: ********
C:\Program Files\MySQL\bin>

สร้างตาราง

เพื่อสร้างไฟล์ Employees ตารางในฐานข้อมูล emp ใช้ขั้นตอนต่อไปนี้ -

ขั้นตอนที่ 1

เปิดไฟล์ Command Prompt และเปลี่ยนเป็นไดเร็กทอรีการติดตั้งดังนี้ -

C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>

ขั้นตอนที่ 2

เข้าสู่ระบบฐานข้อมูลดังนี้ -

C:\Program Files\MySQL\bin>mysql -u root -p
Enter password: ********
mysql>

ขั้นตอนที่ 3

สร้างตาราง Employee ดังต่อไปนี้ -

mysql> use emp;
mysql> create table Employees
    -> (
    -> id int not null,
    -> age int not null,
    -> first varchar (255),
    -> last varchar (255)
    -> );
Query OK, 0 rows affected (0.08 sec)
mysql>

สร้างบันทึกข้อมูล

ในที่สุดคุณก็สร้างเรกคอร์ดสองสามรายการในตารางพนักงานดังนี้ -

mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
Query OK, 1 row affected (0.05 sec)

mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
Query OK, 1 row affected (0.00 sec)

mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
Query OK, 1 row affected (0.00 sec)

mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
Query OK, 1 row affected (0.00 sec)

mysql>

เพื่อความเข้าใจที่สมบูรณ์เกี่ยวกับฐานข้อมูล MySQL, ศึกษากวดวิชา MySQL

ดาวน์โหลด Commons DBUtils Archive

ดาวน์โหลดเวอร์ชันล่าสุดของไฟล์ jar Apache Common DBUtils จากcommons-dbutils-1.7-bin.zip , MySql connector mysql-connector-java-5.1.28-bin.jar , Apache Commons DBCP commons-dbcp2-2.1.1-bin ซิป , Apache คอมมอนส์สระว่ายน้ำcommons-pool2-2.4.3-bin.zipและ Apache Commons เข้าสู่ระบบcommons-logging-1.2-bin.zip ในขณะที่เขียนบทช่วยสอนนี้เราได้ดาวน์โหลดcommons-dbutils-1.7-bin.zip , mysql-connector-java-5.1.28-bin.jar , commons-dbcp2-2.1.1-bin.zip , commons-pool2 -2.4.3-bin.zip , commons-logging-1.2-bin.zipและคัดลอกลงในโฟลเดอร์ C: \> Apache

ระบบปฏิบัติการ ชื่อที่เก็บถาวร
Windows commons-dbutils-1.7-bin.zip
ลินุกซ์ commons-dbutils-1.7-bin.tar.gz
Mac commons-dbutils-1.7-bin.tar.gz

ตั้งค่า Apache Common DBUtils Environment

ตั้งค่า APACHE_HOMEตัวแปรสภาพแวดล้อมเพื่อชี้ไปยังตำแหน่งไดเร็กทอรีฐานที่จัดเก็บ Apache jar ไว้ในเครื่องของคุณ สมมติว่าเราได้แยก commons-dbutils-1.7-bin.zip ในโฟลเดอร์ Apache บนระบบปฏิบัติการต่างๆดังนี้

ระบบปฏิบัติการ เอาต์พุต
Windows ตั้งค่าตัวแปรสภาพแวดล้อม APACHE_HOME เป็น C: \ Apache
ลินุกซ์ ส่งออก APACHE_HOME = / usr / local / Apache
Mac ส่งออก APACHE_HOME = / Library / Apache

ตั้งค่าตัวแปร CLASSPATH

ตั้งค่า CLASSPATHตัวแปรสภาพแวดล้อมเพื่อชี้ไปยังตำแหน่งโถ IO ทั่วไป สมมติว่าคุณเก็บ commons-dbutils-1.7-bin.zip ไว้ในโฟลเดอร์ Apache บนระบบปฏิบัติการต่างๆดังนี้

ระบบปฏิบัติการ เอาต์พุต
Windows ตั้งค่าตัวแปรสภาพแวดล้อม CLASSPATH เป็น% CLASSPATH%;% APACHE_HOME% \ commons-dbutils-1.7.jar; mysql-connector-java-5.1.28.jar; commons-dbcp2-2.1.1.jar; commons-pool2-2.4 3. jar; commons-logging-1.2.jar;
ลินุกซ์ ส่งออก CLASSPATH = $ CLASSPATH: $ APACHE_HOME / commons-dbutils-1.7.jar: mysql-connector-java-5.1.28.jar: commons-dbcp2-2.1.1: commons-pool2-2.4.3.jar: commons-logging -1.2.jar
Mac ส่งออก CLASSPATH = $ CLASSPATH: $ APACHE_HOME / commons-dbutils-1.7.jar: mysql-connector-java-5.1.28: commons-dbcp2-2.1.1.jar: commons-pool2-2.4.3.jar; commons-logging -1.2.jar

ตอนนี้คุณพร้อมที่จะเริ่มทดลองกับ DBUtils แล้ว บทถัดไปจะแสดงตัวอย่างของ DBUtils Programming

บทนี้แสดงตัวอย่างวิธีการสร้างแอ็พพลิเคชัน JDBC อย่างง่ายโดยใช้ไลบรารี DBUtils สิ่งนี้จะแสดงวิธีเปิดการเชื่อมต่อฐานข้อมูลดำเนินการสืบค้น SQL และแสดงผลลัพธ์

ขั้นตอนทั้งหมดที่กล่าวถึงในตัวอย่างเทมเพลตนี้จะอธิบายในบทต่อ ๆ ไปของบทช่วยสอนนี้

การสร้าง JDBC Application

มีหกขั้นตอนที่เกี่ยวข้องในการสร้างแอปพลิเคชัน JDBC ดังต่อไปนี้ -

  • Import the packages- กำหนดให้คุณรวมแพ็กเกจที่มีคลาส JDBC ซึ่งจำเป็นสำหรับการเขียนโปรแกรมฐานข้อมูล บ่อยที่สุดโดยใช้import java.sql.* จะพอเพียง

  • Register the JDBC driver - ต้องการให้คุณเริ่มต้นไดรเวอร์เพื่อให้คุณสามารถเปิดช่องทางการสื่อสารกับฐานข้อมูลได้

  • Open a connection - ต้องใช้ไฟล์ DriverManager.getConnection() วิธีการสร้างวัตถุการเชื่อมต่อซึ่งแสดงถึงการเชื่อมต่อทางกายภาพกับฐานข้อมูล

  • Execute a query - ต้องใช้ออบเจ็กต์ประเภท Statement เพื่อสร้างและส่งคำสั่ง SQL ไปยังฐานข้อมูล

  • Extract data from result set - ต้องการให้คุณใช้ที่เหมาะสม ResultSet.getXXX() วิธีการดึงข้อมูลจากชุดผลลัพธ์

  • Clean up the environment - ต้องปิดทรัพยากรฐานข้อมูลทั้งหมดอย่างชัดเจนเมื่อเทียบกับการรวบรวมขยะของ JVM

ตัวอย่างรหัส

ตัวอย่างตัวอย่างนี้สามารถใช้เป็นเทมเพลตเมื่อคุณต้องการสร้างแอปพลิเคชัน JDBC ของคุณเองในอนาคต

โค้ดตัวอย่างนี้ถูกเขียนขึ้นตามสภาพแวดล้อมและการตั้งค่าฐานข้อมูลที่ทำในบทที่แล้ว

คัดลอกและวางตัวอย่างต่อไปนี้ใน MainApp.java คอมไพล์และรันดังนี้ -

MainApp.java

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

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

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<Employee> resultHandler = new BeanHandler<Employee>(Employee.class);
      
      try {
         Employee emp = queryRunner.query(conn,
            "SELECT * FROM employees WHERE first=?", resultHandler, "Sumit");
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", First: " + emp.getFirst());
         System.out.println(", Last: " + emp.getLast());
      } finally {
         DbUtils.close(conn);
      }
   }
}

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;
   }
}

ตอนนี้ให้เรารวบรวมตัวอย่างข้างต้นดังนี้ -

C:\>javac MainApp.java Employee.java
C:\>

เมื่อคุณเรียกใช้ MainAppมันให้ผลลัพธ์ดังต่อไปนี้ -

C:\>java MainApp
Connecting to database...
ID: 103, Age: 28, First: Sumit, Last: Mittal
C:\>

ตัวอย่างต่อไปนี้จะสาธิตวิธีสร้างเรกคอร์ดโดยใช้แทรกคิวรีด้วยความช่วยเหลือของ DBUtils เราจะแทรกบันทึกในตารางพนักงาน

ไวยากรณ์

ไวยากรณ์ในการสร้างแบบสอบถามได้รับด้านล่าง -

String insertQuery ="INSERT INTO employees(id,age,first,last) VALUES (?,?,?,?)";
int insertedRecords = queryRunner.update(conn, insertQuery,104,30, "Sohan","Kumar");

ที่ไหน

  • insertQuery - แทรกแบบสอบถามที่มีตัวยึด

  • queryRunner - วัตถุ QueryRunner เพื่อแทรกวัตถุพนักงานในฐานข้อมูล

เพื่อให้เข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแทรก ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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();
      DbUtils.loadDriver(JDBC_DRIVER);
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      try {
         int insertedRecords = queryRunner.update(conn,
            "INSERT INTO employees(id,age,first,last) VALUES (?,?,?,?)",
            104,30, "Sohan","Kumar");
         System.out.println(insertedRecords + " record(s) inserted");
      } finally {
         DbUtils.close(conn);
      }
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้ -

1 record(s) inserted.

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านบันทึกโดยใช้คิวรีอ่านด้วยความช่วยเหลือของ DBUtils เราจะอ่านบันทึกจากตารางพนักงาน

ไวยากรณ์

ไวยากรณ์สำหรับการสอบถามการอ่านมีการระบุไว้ด้านล่าง -

ResultSetHandler<Employee> resultHandler = new BeanHandler<Employee>(Employee.class);
Employee emp = queryRunner.query(conn, "SELECT * FROM employees WHERE first=?", resultHandler, "Sumit");

ที่ไหน

  • resultHandler - วัตถุ ResultSetHandler เพื่อแมปผลลัพธ์ที่ตั้งไว้กับวัตถุของพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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<Employee> resultHandler =
         new BeanHandler<Employee>(Employee.class);
      try {
         Employee emp = queryRunner.query(conn,
            "SELECT * FROM employees WHERE id=?", resultHandler, 104);
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", First: " + emp.getFirst());
         System.out.println(", Last: " + emp.getLast());
      } finally {
         DbUtils.close(conn);
      }
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันจะพิมพ์ข้อความต่อไปนี้:

ID: 104, Age: 30, First: Sohan, Last: Kumar

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอัพเดตเรกคอร์ดโดยใช้อัพเดตเคียวรีด้วยความช่วยเหลือของ DBUtils เราจะอัปเดตบันทึกในตารางพนักงาน

ไวยากรณ์

ไวยากรณ์สำหรับการสอบถามการอัปเดตมีดังนี้ -

String updateQuery = "UPDATE employees SET age=? WHERE id=?";
int updatedRecords = queryRunner.update(conn, updateQuery, 33,104);

ที่ไหน

  • updateQuery - อัปเดตแบบสอบถามที่มีตัวยึดตำแหน่ง

  • queryRunner - วัตถุ QueryRunner เพื่ออัปเดตวัตถุของพนักงานในฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามการอัปเดต ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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();
      DbUtils.loadDriver(JDBC_DRIVER);
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      try {
         int updatedRecords = queryRunner.update(conn,
            "UPDATE employees SET age=? WHERE id=?", 33,104);
         System.out.println(updatedRecords + " record(s) updated.");
      } finally {
         DbUtils.close(conn);
      }
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้ -

1 record(s) updated.

ตัวอย่างต่อไปนี้จะสาธิตวิธีการลบระเบียนโดยใช้ Delete query ด้วยความช่วยเหลือของ DBUtils เราจะลบบันทึกในตารางพนักงาน

ไวยากรณ์

ไวยากรณ์สำหรับการสืบค้นการลบมีการระบุไว้ด้านล่าง -

String deleteQuery = "DELETE FROM employees WHERE id=?";
int deletedRecords = queryRunner.delete(conn, deleteQuery, 33,104);

ที่ไหน

  • deleteQuery - ลบแบบสอบถามที่มีตัวยึด

  • queryRunner - วัตถุ QueryRunner เพื่อลบวัตถุพนักงานในฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดดังกล่าวข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามลบ ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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();
      DbUtils.loadDriver(JDBC_DRIVER);
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      try {
         int deletedRecords = queryRunner.update(conn,
            "DELETE from employees WHERE id=?", 104);
         System.out.println(deletedRecords + " record(s) deleted.");
      } finally {
         DbUtils.close(conn);
      }
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยดีกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้ -

1 record(s) deleted.

org.apache.commons.dbutils.QueryRunnerคลาสเป็นคลาสกลางในไลบรารี DBUtils ดำเนินการสืบค้น SQL ด้วยกลยุทธ์แบบเสียบได้สำหรับการจัดการ ResultSets คลาสนี้ปลอดภัยต่อเธรด

การประกาศคลาส

ต่อไปนี้เป็นการประกาศสำหรับคลาส org.apache.commons.dbutils.QueryRunner -

public class QueryRunner
   extends AbstractQueryRunner

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - ใช้วิธีการวัตถุ QueryRunner เพื่อดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านบันทึกโดยใช้คลาส QueryRunner เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงาน

ไวยากรณ์

ResultSetHandler<Employee> resultHandler = new BeanHandler<Employee>(Employee.class);
Employee emp = 
   queryRunner.query(conn, "SELECT * FROM employees WHERE first=?", resultHandler, "Sumit");

ที่ไหน

  • resultHandler - วัตถุ ResultSetHandler เพื่อแมปผลลัพธ์ที่กำหนดเป็นวัตถุพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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<Employee> resultHandler = new BeanHandler<Employee>(Employee.class);

      try {
         Employee emp = queryRunner.query(conn,
            "SELECT * FROM employees WHERE id=?", resultHandler, 103);
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", First: " + emp.getFirst());
         System.out.println(", Last: " + emp.getLast());
      } finally {
         DbUtils.close(conn);
      }        
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

ID: 103, Age: 28, First: Sumit, Last: Mittal

org.apache.commons.dbutils.AsyncQueryRunnerคลาสช่วยในการรันคิวรี SQL ที่รันเป็นเวลานานด้วยการสนับสนุน async คลาสนี้ปลอดภัยต่อเธรด คลาสนี้สนับสนุนวิธีการเดียวกับ QueryRunner แต่จะส่งคืนอ็อบเจ็กต์ที่เรียกได้ซึ่งสามารถใช้ในภายหลังเพื่อดึงผลลัพธ์

การประกาศคลาส

ต่อไปนี้คือการประกาศสำหรับคลาส org.apache.commons.dbutils AsyncQueryRunner -

public class AsyncQueryRunner
   extends AbstractQueryRunner

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - ใช้วิธีการวัตถุ AsyncQueryRunner เพื่อดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอัปเดตระเบียนโดยใช้คลาส AsyncQueryRunner เราจะอัปเดตบันทึกที่มีอยู่ในตารางพนักงาน

ไวยากรณ์

String updateQuery = "UPDATE employees SET age=? WHERE id=?";
future = asyncQueryRunner.update(conn,
            "UPDATE employees SET age=? WHERE id=?", 33,103);

ที่ไหน

  • updateQuery - อัปเดตแบบสอบถามที่มีตัวยึดตำแหน่ง

  • asyncQueryRunner - วัตถุ asyncQueryRunner เพื่ออัปเดตวัตถุพนักงานในฐานข้อมูล

  • future - วัตถุในอนาคตเพื่อดึงผลลัพธ์ในภายหลัง

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามการอัปเดตในโหมด async ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException; 
import java.util.concurrent.ExecutorCompletionService; 
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; 
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;

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, InterruptedException, 
      ExecutionException, TimeoutException {
      Connection conn = null;

      AsyncQueryRunner asyncQueryRunner = new AsyncQueryRunner( Executors.newCachedThreadPool());

      DbUtils.loadDriver(JDBC_DRIVER);       
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      Future<Integer> future = null;
      try {
         future = asyncQueryRunner.update(conn, 
            "UPDATE employees SET age=? WHERE id=?", 33,103);         
         Integer updatedRecords = future.get(10, TimeUnit.SECONDS);
         System.out.println(updatedRecords + " record(s) updated.");
      } finally {
         DbUtils.close(conn);
      }  
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

1 record(s) updated.

org.apache.commons.dbutils.ResultSetHandler อินเทอร์เฟซมีหน้าที่ในการแปลง ResultSets เป็นวัตถุ

การประกาศคลาส

ต่อไปนี้เป็นการประกาศสำหรับคลาส org.apache.commons.dbutils.ResultSetHandler -

public interface ResultSetHandler<T>

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - สร้างการใช้งาน ResultSetHandler

  • Step 3 - ส่ง resultSetHandler ไปยังวัตถุ QueryRunner และดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการแม็พเรกคอร์ดโดยใช้คลาส ResultSetHandler เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงาน

ไวยากรณ์

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

ที่ไหน

  • resultHandler - วัตถุ ResultSetHandler เพื่อแมปผลลัพธ์ที่กำหนดเป็นวัตถุพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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);
      }              
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

org.apache.commons.dbutils.BeanHandlerคือการนำอินเทอร์เฟซ ResultSetHandler มาใช้และรับผิดชอบในการแปลงแถว ResultSet แรกเป็น JavaBean คลาสนี้ปลอดภัยต่อเธรด

การประกาศคลาส

ต่อไปนี้เป็นคำประกาศสำหรับคลาส org.apache.commons.dbutils BeanHandler -

public class BeanHandler<T>
   extends Object implements ResultSetHandler<T>

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - รับการใช้งาน ResultSetHandler เป็นวัตถุ BeanHandler

  • Step 3 - ส่ง resultSetHandler ไปยังวัตถุ QueryRunner และดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านบันทึกโดยใช้คลาส BeanHandler เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงานและแมปกับ Employee bean

ไวยากรณ์

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

ที่ไหน

  • resultHandler - วัตถุ BeanHandler เพื่อแมปผลลัพธ์ที่กำหนดเป็นวัตถุพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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<Employee> resultHandler 
         = new BeanHandler<Employee>(Employee.class);

      try {
         Employee emp = queryRunner.query(conn,
            "SELECT * FROM employees WHERE first=?", resultHandler, "Sumit");
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", First: " + emp.getFirst());
         System.out.println(", Last: " + emp.getLast());
      } finally {
         DbUtils.close(conn);
      }              
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

ID: 103, Age: 28, First: Sumit, Last: Mittal

org.apache.commons.dbutils.BeanListHandlerคือการนำอินเทอร์เฟซ ResultSetHandler มาใช้และรับผิดชอบในการแปลงแถว ResultSet เป็นรายการ Java Bean คลาสนี้ปลอดภัยต่อเธรด

การประกาศคลาส

ต่อไปนี้คือการประกาศสำหรับคลาส org.apache.commons.dbutils BeanListHandler -

public class BeanListHandler<T>
   extends Object implements ResultSetHandler<List<T>>

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - รับการใช้งาน ResultSetHandler เป็นวัตถุ BeanListHandler

  • Step 3 - ส่ง resultSetHandler ไปยังวัตถุ QueryRunner และดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านรายการบันทึกโดยใช้คลาส BeanListHandler เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงานและจับคู่กับรายการของพนักงาน

ไวยากรณ์

List<Employee> empList = queryRunner.query(conn, "SELECT * FROM employees", resultHandler);

ที่ไหน

  • resultHandler - BeanListHandler วัตถุเพื่อแมปชุดผลลัพธ์เป็นรายการวัตถุพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.List;

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

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 List of Employee Beans
      ResultSetHandler<List<Employee>> resultHandler = new BeanListHandler<Employee>(Employee.class);

      try {
         List<Employee> empList = queryRunner.query(conn, "SELECT * FROM employees", resultHandler);
         for(Employee emp: empList ) {
            //Display values
            System.out.print("ID: " + emp.getId());
            System.out.print(", Age: " + emp.getAge());
            System.out.print(", First: " + emp.getFirst());
            System.out.println(", Last: " + emp.getLast());
         }           
      } finally {
         DbUtils.close(conn);
      }        
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

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

org.apache.commons.dbutils.ArrayListHandlerคือการนำอินเทอร์เฟซ ResultSetHandler มาใช้และรับผิดชอบในการแปลงแถว ResultSet เป็นอ็อบเจ็กต์ [] คลาสนี้ปลอดภัยต่อเธรด

การประกาศคลาส

ต่อไปนี้เป็นการประกาศสำหรับคลาส org.apache.commons.dbutils.ArrayListHandler -

public class ArrayListHandler
   extends AbstractListHandler<Object[]>

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - รับการใช้งาน ResultSetHandler เป็นวัตถุ ArrayListHandler

  • Step 3 - ส่ง resultSetHandler ไปยังวัตถุ QueryRunner และดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านรายการบันทึกโดยใช้คลาส ArrayListHandler เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงานเป็นวัตถุ []

ไวยากรณ์

List<Object> result = queryRunner.query(conn, "SELECT * FROM employees", new ArrayListHandler());

ที่ไหน

  • resultHandler - วัตถุ ArrayListHandler เพื่อแมปชุดผลลัพธ์เป็นรายการวัตถุ []

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayListHandler;

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);        

      try {
         List<Object[]> result = queryRunner.query(conn, "SELECT * FROM employees"
            , new ArrayListHandler());  
         for(Object[] objects : result) {
            System.out.println(Arrays.toString(objects));
         }           
      } finally {
         DbUtils.close(conn);
      }        
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

[100, 18, Zara, Ali]
[101, 25, Mahnaz, Fatma]
[102, 30, Zaid, Khan]
[103, 28, Sumit, Mittal]

org.apache.commons.dbutils.MapListHandlerคือการนำอินเทอร์เฟซ ResultSetHandler มาใช้และมีหน้าที่ในการแปลงแถว ResultSet เป็นรายการแผนที่ คลาสนี้ปลอดภัยต่อเธรด

การประกาศคลาส

ต่อไปนี้เป็นการประกาศสำหรับคลาส org.apache.commons.dbutils.MapListHandler -

public class MapListHandler
   extends AbstractListHandler<Map<String,Object>>

การใช้งาน

  • Step 1 - สร้างวัตถุเชื่อมต่อ

  • Step 2 - รับการใช้งาน ResultSetHandler เป็นวัตถุ MapListHandler

  • Step 3 - ส่ง resultSetHandler ไปยังวัตถุ QueryRunner และดำเนินการฐานข้อมูล

ตัวอย่าง

ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านรายการบันทึกโดยใช้คลาส MapListHandler เราจะอ่านบันทึกที่มีอยู่ในตารางพนักงานเป็นรายการแผนที่

ไวยากรณ์

List<Map<String, Object>> result = queryRunner.query(conn, "SELECT * FROM employees", new MapListHandler());

ที่ไหน

  • resultHandler - วัตถุ MapListHandler เพื่อกำหนดผลลัพธ์แผนที่เป็นรายการแผนที่

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.MapListHandler;

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);        

      try {
         List<Map<String, Object>> result = queryRunner.query(
            conn, "SELECT * FROM employees", new MapListHandler());      
         System.out.println(result);
      } finally {
         DbUtils.close(conn);
      }        
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

Connecting to database...
[{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=33, first=Sumit, last=Mittal}]

เราสามารถสร้างตัวจัดการแบบกำหนดเองของเราเองได้โดยใช้อินเทอร์เฟซ ResultSetHandler หรือขยายการใช้งาน ResultSetHandler ที่มีอยู่ ในตัวอย่างด้านล่างเราได้สร้าง Custom Handler, EmployeeHandler โดยขยายคลาส BeanHandler

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ Employee.java.

public class Employee {
   private int id;
   private int age;
   private String first;
   private String last;
   private String name;
   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;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ EmployeeHandler.java ไฟล์.

import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.commons.dbutils.handlers.BeanHandler;

public class EmployeeHandler extends BeanHandler<Employee> {

   public EmployeeHandler() {
      super(Employee.class);
   }

   @Override
   public Employee handle(ResultSet rs) throws SQLException {
      Employee employee = super.handle(rs);
      employee.setName(employee.getFirst() +", " + employee.getLast());
      return employee;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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();
      DbUtils.loadDriver(JDBC_DRIVER);                 
      conn = DriverManager.getConnection(DB_URL, USER, PASS);        
      EmployeeHandler employeeHandler = new EmployeeHandler();

      try {
         Employee emp = queryRunner.query(conn,
         "SELECT * FROM employees WHERE first=?", employeeHandler, "Sumit");
         
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", Name: " + emp.getName());
      } finally {
         DbUtils.close(conn);
      }        
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

ID: 103, Age: 28, Name: Sumit, Mittal

ในกรณีที่ชื่อคอลัมน์ในตารางฐานข้อมูลและชื่ออ็อบเจ็กต์ javabean ที่เท่ากันไม่เหมือนกันเราสามารถแม็พได้โดยใช้อ็อบเจ็กต์ BasicRowProcessor ที่กำหนดเอง ดูตัวอย่างด้านล่าง

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ Employee.java.

public class Employee {
   private int id;
   private int age;
   private String first;
   private String last;
   private String name;
   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;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ EmployeeHandler.java ไฟล์.

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;

import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.BeanProcessor;
import org.apache.commons.dbutils.BasicRowProcessor;

public class EmployeeHandler extends BeanHandler<Employee> {

   public EmployeeHandler() {
      super(Employee.class, new BasicRowProcessor(new BeanProcessor(mapColumnsToFields())));
   }

   @Override
   public Employee handle(ResultSet rs) throws SQLException {
      Employee employee = super.handle(rs);
      employee.setName(employee.getFirst() +", " + employee.getLast());
      return employee;
   }
   
   public static Map<String, String> mapColumnsToFields() {
      Map<String, String> columnsToFieldsMap = new HashMap<>();
      columnsToFieldsMap.put("ID", "id");
      columnsToFieldsMap.put("AGE", "age");        
      return columnsToFieldsMap;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

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

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

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();      
      DbUtils.loadDriver(JDBC_DRIVER);                 
      conn = DriverManager.getConnection(DB_URL, USER, PASS);        
      EmployeeHandler employeeHandler = new EmployeeHandler();

      try {
         Employee emp = queryRunner.query(conn,
           "SELECT * FROM employees WHERE first=?", employeeHandler, "Sumit");
         
         //Display values
         System.out.print("ID: " + emp.getId());
         System.out.print(", Age: " + emp.getAge());
         System.out.print(", Name: " + emp.getName());
      } finally {
         DbUtils.close(conn);
      }              
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

ID: 103, Age: 28, Name: Sumit, Mittal

จนถึงตอนนี้เราใช้วัตถุการเชื่อมต่อในขณะที่ใช้ QueryRunner เรายังสามารถใช้ datasource ได้อีกด้วย ตัวอย่างต่อไปนี้จะสาธิตวิธีการอ่านเรกคอร์ดโดยใช้คิวรีอ่านด้วยความช่วยเหลือของ QueryRunner และแหล่งข้อมูล เราจะอ่านบันทึกจากตารางพนักงาน

ไวยากรณ์

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

ที่ไหน

  • dataSource - กำหนดค่าวัตถุ DataSource

  • resultHandler - วัตถุ ResultSetHandler เพื่อแมปผลลัพธ์ที่กำหนดเป็นวัตถุพนักงาน

  • queryRunner - วัตถุ QueryRunner เพื่ออ่านวัตถุของพนักงานจากฐานข้อมูล

เพื่อทำความเข้าใจแนวคิดที่กล่าวถึงข้างต้นที่เกี่ยวข้องกับ DBUtils ให้เราเขียนตัวอย่างซึ่งจะเรียกใช้แบบสอบถามแบบอ่าน ในการเขียนตัวอย่างให้เราสร้างแอปพลิเคชันตัวอย่าง

ขั้นตอน คำอธิบาย
1 ปรับปรุงแฟ้มMainApp.javaสร้างขึ้นภายใต้บทDBUtils - การใช้งานครั้งแรก
2 รวบรวมและเรียกใช้แอปพลิเคชันตามคำอธิบายด้านล่าง

ต่อไปนี้เป็นเนื้อหาของไฟล์ 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;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ CustomDatasource.java.

import javax.sql.DataSource;
import org.apache.commons.dbcp2.BasicDataSource;

public class CustomDataSource {
   // 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";
   private static DataSource datasource;
   private static final BasicDataSource basicDataSource;

   static {
      basicDataSource = new BasicDataSource();
      basicDataSource.setDriverClassName(JDBC_DRIVER);
      basicDataSource.setUsername(USER);
      basicDataSource.setPassword(PASS);
      basicDataSource.setUrl(DB_URL);
   }

   public static DataSource getInstance() {
      return basicDataSource;
   }
}

ต่อไปนี้เป็นเนื้อหาของไฟล์ MainApp.java ไฟล์.

import java.sql.SQLException;

import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;

public class MainApp {
   public static void main(String[] args) throws SQLException {    
      
      DbUtils.loadDriver(JDBC_DRIVER);
      QueryRunner run = new QueryRunner(CustomDataSource.getInstance());
      ResultSetHandler<Employee> resultHandler = new BeanHandler<Employee>(Employee.class);

      Employee emp = queryRunner.query("SELECT * FROM employees WHERE id=?",
         resultHandler, 103);
      
      //Display values
      System.out.print("ID: " + emp.getId());
      System.out.print(", Age: " + emp.getAge());
      System.out.print(", First: " + emp.getFirst());
      System.out.println(", Last: " + emp.getLast());
   }
}

เมื่อคุณสร้างไฟล์ต้นฉบับเสร็จแล้วให้เราเรียกใช้แอปพลิเคชัน หากทุกอย่างเรียบร้อยกับแอปพลิเคชันของคุณแอปพลิเคชันของคุณจะพิมพ์ข้อความต่อไปนี้

ID: 103, Age: 33, First: Sumit, Last: Mittal