Apache Commons DbUtils Tutorial 輕量級JDBC工具

The Apache Commons DbUtils library is a small set of classes designed to make working with JDBC easier. JDBC resource cleanup code is mundane, error prone work so these classes abstract out all of the cleanup tasks from your code leaving you with what you really wanted to do with JDBC in the first place: query and update data.java

Advantages of Using DbUtils are:

  1. No possibilities for resource leak.mysql

  2. Cleaner, clearer persistence code. The amount of code needed to persist data in a database is drastically reduced.sql

  3. Automatically populate JavaBean properties from ResultSets. You don’t need to manually copy column values into bean instances by calling setter methods. Each row of the ResultSet can be represented by one fully populated bean instance.apache

The main classes used from this DbUtils library are DbUtils, QueryRunner and the ResultSetHandler.fetch

DbUtils: A collection of JDBC helper methods, all the methods in this class are static, and this class is a thread safe means multiple threads can access concurrently.ui

ResultSetHandler: It is an interface, implementations of this interface convert ResultSets into other objects.this

  1. BeanHandler: It converts the ResultSet row into a JavaBean.url

  2. MapHandler: It converts the ResultSet row into a Map.spa

  3. BeanListHandler: It converts a ResultSet into a List of beans. etccode

QueryRunner: Executes SQL queries with pluggable strategies for handling ResultSets. This class is thread safe.

Simple example to use DbUtils, QueryRunner and ResultSetHandler:

1. The User table, here is the script to create the database table and inserting the data into the User table.

CREATE TABLE IF NOT EXISTS `user` (
 `userId` int(11) NOT NULL AUTO_INCREMENT,
 `firstName` varchar(50) NOT NULL,
 `lastName` varchar(50) NOT NULL,
 `phoneNo` varchar(50) NOT NULL,
 `emailId` varchar(50) NOT NULL,
 PRIMARY KEY (`userId`)
) ENGINE=InnoDB;

INSERT INTO `user` (`userId`, `firstName`, `lastName`, `phoneNo`, `emailId`) VALUES
(1, 'Pramod', 'Ganta', '9889885566', 'pramod@codesuggestions.com'),
(2, 'Suman', 'Manthena', '8858863456', 'suman@codesuggestions.com'),
(3, 'Prakash', 'Puli', '9889885566', 'prakash@codesuggestions.com'),
(4, 'Rohit', 'Sunkari', '8858863456', 'rohit@codesuggestions.com');

2. The Java Bean class representing the User table. The property name are same as the column names in User table.

package com.sc.dbutils;

public class User {
   private String userId;
   private String firstName;
   private String lastName;
   private String phoneNO;
   private String emailId;
   
   public User(){
   }

   public String getUserId() {
       return userId;
   }

   public void setUserId(String userId) {
       this.userId = userId;
   }

   public String getFirstName() {
       return firstName;
   }

   public void setFirstName(String firstName) {
       this.firstName = firstName;
   }

   public String getLastName() {
       return lastName;
   }

   public void setLastName(String lastName) {
       this.lastName = lastName;
   }

   public String getPhoneNO() {
       return phoneNO;
   }

   public void setPhoneNO(String phoneNO) {
       this.phoneNO = phoneNO;
   }

   public String getEmailId() {
       return emailId;
   }

   public void setEmailId(String emailId) {
       this.emailId = emailId;
   }
}

3. In this example class using BeanHandler which is the implementation of the ResultSetHandler interface, and it returns the ResultSet into a Java Bean Object.

package com.sc.dbutils;

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.handlers.BeanHandler;

public class DbUtilsBeanHandler {
   public static void main(String[] args) {
       Connection conn = null;
       String url = "jdbc:mysql://localhost:3306/test";
       String driver = "com.mysql.jdbc.Driver";
       String usr = "root";
       String pwd = "";
       User user = null;
       try {
           //Loading the Driver using DbUtils static method
           DbUtils.loadDriver(driver);
           conn = DriverManager.getConnection(url, usr, pwd);
           QueryRunner query = new QueryRunner();
           user = (User) query.query(conn, "select * from user where userId=3", new BeanHandler(User.class));
           
           System.out.println("User Object::  " + user.getUserId() + "\t" + user.getFirstName() + "\t" + user.getLastName() + "\t" + user.getEmailId());
           
       } catch (SQLException se) {
           se.printStackTrace();
       } finally {
           //Closing the connection quietly, means it will handles the SQLException
           DbUtils.closeQuietly(conn);
       }
   }
}

Output:

User Object::  3 Prakash Puli

4. In this example class using BeanListHandler which also the implementation of the ResultSetHandler interface, and it returns the ResultSet into a List of Java Bean Objects.

package com.sc.dbutils;

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.handlers.BeanListHandler;

public class DbUtilsBeanListHandler {

   public static void main(String[] args) {
       Connection conn = null;
       String url = "jdbc:mysql://localhost:3306/test";
       String driver = "com.mysql.jdbc.Driver";
       String user = "root";
       String pwd = "";
       Listusers = null;
       try {
           DbUtils.loadDriver(driver);
           conn = DriverManager.getConnection(url, user, pwd);
           QueryRunner query = new QueryRunner();
           users = (List) query.query(conn, "select * from user", new BeanListHandler(User.class));
           for (int i = 0; i < users.size(); i++) {
               User bean = users.get(i);
               System.out.println("User Objects::  " + bean.getUserId() + "\t" + bean.getFirstName() + "\t" + bean.getLastName() + "\t" + bean.getEmailId());
           }
       } catch (SQLException se) {
           se.printStackTrace();
       } finally {
           DbUtils.closeQuietly(conn);
       }
   }
}

Output:

User Objects::  1 Pramod Ganta pramod@codesuggestions.com
User Objects::  2 Suman Manthena suman@codesuggestions.com
User Objects::  3 Prakash Puli prakash@codesuggestions.com
User Objects::  4 Rohit Sunkari rohit@codesuggestions.com

5. In this example class using MapListHandler which also the implementation of the ResultSetHandler interface, and it returns the ResultSet into a List of Map Objects. The Map object contains the each row, the column name as key and value as value in the Map object.

package com.sc.dbutils;

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 DbUtilsMapListHandler {

   public static void main(String[] args) {
       Connection conn = null;
       String url = "jdbc:mysql://localhost:3306/test";
       String driver = "com.mysql.jdbc.Driver";
       String user = "root";
       String pwd = "";
       try {
           DbUtils.loadDriver(driver);
           conn = DriverManager.getConnection(url, user, pwd);
           QueryRunner query = new QueryRunner();
           List mapList = (List) query.query(conn, "select * from user", new MapListHandler());
           for (int i = 0; i < mapList.size(); i++) {
               Map map = (Map) mapList.get(i);
               System.out.println("------> " + map.get("userId") + "\t" + map.get("firstName") + "\t" + map.get("emailId"));
           }
       } catch (SQLException se) {
           se.printStackTrace();
       } finally {
           DbUtils.closeQuietly(conn);
       }
   }
}

Output:

------> 1 Pramod pramod@codesuggestions.com
------> 2 Suman suman@codesuggestions.com
------> 3 Prakash prakash@codesuggestions.com
------> 4 Rohit rohit@codesuggestions.com

Note: When we fetching from the Map, if we give the wrong column name it ruturn null value. Ex: map.get("fistName"), here mispelling the firstName. The same with BeanHandler to, if the Bean properties and table columns are not in match, it will return null values.

6. In this example class using the BeanListHandler with out the QueryRunner class, and using the handle() method which takes the ResultSet as the parameter to this method, this method returns List of Bean objects.

package com.sc.dbutils;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.List;
import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.handlers.BeanListHandler;

public class DbUtilsTest1{
   public static void main(String[] args) {
       Connection conn = null;
       Statement stmt = null;
       ResultSet rs = null;
       String url = "jdbc:mysql://localhost:3306/test";
       String driver = "com.mysql.jdbc.Driver";
       String usr = "root";
       String pwd = "";
       Listusers = null;
       try {
           DbUtils.loadDriver(driver);
           conn = DriverManager.getConnection(url, usr, pwd);
           stmt = conn.createStatement();
           rs = stmt.executeQuery("SELECT * FROM user");
           BeanListHandler listHandler = new BeanListHandler(User.class);
           users = listHandler.handle(rs);
           
           for(User user : users){
               System.out.println("User Object:: " + user.getUserId() + "\t" + user.getFirstName() + "\t" + user.getEmailId());
           }
           
       } catch (SQLException se) {
           se.printStackTrace();
       } finally {
           DbUtils.closeQuietly(conn);
       }
   }
}

Output:

User Object:: 1 Pramod pramod@codesuggestions.com
User Object:: 2 Suman suman@codesuggestions.com
User Object:: 3 Prakash prakash@codesuggestions.com
User Object:: 4 Rohit rohit@codesuggestions.com

7. In this example class using the MapListHandler without the QueryRunner class, and using the handle() method which takes the ResultSet as the parameter to this method, this method returns List of Map Objects.

package com.sc.dbutils;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;

public class DbUtilsTest2 {
   public static void main(String[] args) {
       Connection conn = null;
       Statement stmt = null;
       ResultSet rs = null;
       String url = "jdbc:mysql://localhost:3306/test";
       String driver = "com.mysql.jdbc.Driver";
       String usr = "root";
       String pwd = "";
       List> userMaps = null;
       try {
           //Loading the Driver using DbUtils static method
           DbUtils.loadDriver(driver);
           conn = DriverManager.getConnection(url, usr, pwd);
           stmt = conn.createStatement();
           rs = stmt.executeQuery("SELECT * FROM user");
           MapListHandler mapListHandler = new MapListHandler();
           userMaps = mapListHandler.handle(rs);
           
           for(MapmapObj : userMaps){
               System.out.println("User Object::  " + mapObj.get("userId") + "\t" + mapObj.get("lastName") + "\t" + mapObj.get("phoneNo"));
           }
           
       } catch (SQLException se) {
           se.printStackTrace();
       } finally {
           //Closing the connection quietly, means it will handles the SQLException
           DbUtils.closeQuietly(conn);
       }
   }
}

Output:

User Object::  1 Ganta 9889885566
User Object::  2 Manthena 8858863456
User Object::  3 Puli 9889885566
User Object::  4 Sunkari 8858863456

I hope this tutorial has given brief introduction about the Apache Commons DbUtils Library.

相關文章
相關標籤/搜索