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