美文网首页
commons-dbutils工具介绍及实战

commons-dbutils工具介绍及实战

作者: 果子学长 | 来源:发表于2020-02-26 20:26 被阅读0次

    1.commons-dbutils简介

    commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用dbutils能极大简化jdbc编码的工作量,同时也不会影响程序的性能。

    API介绍:

    •org.apache.commons.dbutils.QueryRunner

    •org.apache.commons.dbutils.ResultSetHandler

    •工具类

    org.apache.commons.dbutils.DbUtils

    链接如下:

    https://commons.apache.org/proper/commons-dbutils/

    2.DbUtils类介绍

    DbUtils :提供如关闭连接、装载JDBC驱动程序等常规工作的工具类,里面的所有方法都是静态的(关闭资源、加载驱动)。主要方法如下:

    •public static void close(…) throws java.sql.SQLException: DbUtils类提供了三个重载的关闭方法。这些方法检查所提供的参数是不是NULL,如果不是的话,它们就关闭Connection、Statement和ResultSet。

    •public static void closeQuietly(…): 这一类方法不仅能在Connection、Statement和ResultSet为NULL情况下避免关闭,还能隐藏一些在程序中抛出的SQLException。

    •public static void commitAndCloseQuietly(Connection

    conn):

    用来提交连接,然后关闭连接,并且在关闭连接时不抛出SQL异常。

    •public static boolean loadDriver(java.lang.String driverClassName):这一方装载并注册JDBC驱动程序,如果成功就返回true。使用该方法,你不需要捕捉这个异常ClassNotFoundException。

    3.QueryRunner类 介绍

    该类简单化了SQL查询,它与ResultSetHandler组合在一起使用可以完成大部分的数据库操作,能够大大减少编码量。(核心工具类,定义了所有的与数据库操作的方法(查询、更新))

    QueryRunner类提供了两个构造方法:

    •默认的构造方法

    需要一个 javax.sql.DataSource 来作参数的构造方法

    QueryRunner类的主要方法

    public Object query(Connection conn,String sql,Object[] params, ResultSetHandler rsh)

    throws SQLException:执行一个查询操作,在这个查询中,对象数组中的每个元素值被用来作为查询语句的置换参数。该方法会自行处理 PreparedStatement和ResultSet的创建和关闭。

    public Object query(String sql,Object[] params, ResultSetHandler rsh) throws SQLException: 几乎与第一种方法一样;唯一的不同在于它不将数据库连接提供给方法,并且它是从提供给构造方法的数据源(DataSource) 或使用的setDataSource 方法中重新获得 Connection。

    public Object query(Connection conn,String sql, ResultSetHandler rsh) throws SQLException : 执行一个不需要置换参数的查询操作。

    public int update(Connection conn, String sql,Object[] params) throws SQLException:用来执行一个更新(插入、更新或删除)操作。

    public int update(Connection conn, String sql) throws SQLException:用来执行一个不需要置换参数的更新操作。

    4.ResultSetHandler接口

    该接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。

    ResultSetHandler接口提供了一个单独的方法:Object

    handle (java.sql.ResultSet .rs)。

    ResultSetHandler 接口的实现类

    ArrayHandler:把结果集中的第一行数据转成对象数组

    ArrayListHandler:把结果集中的每一行数据都转成一个数组,再存放到List中。

    BeanHandler:将结果集中的第一行数据封装到一个对应的JavaBean实例中。

    BeanListHandler:将结果集中的每一行数据都封装到一个对应的JavaBean实例中,存放到List里。

    ColumnListHandler(列名):将结果集中某一列的数据存放到List中。

    KeyedHandler(name):将结果集中的每一行数据都封装到一个Map里,再把这些map再存到一个map里,其key为指定的key。

    MapHandler:将结果集中的第一行数据封装到一个Map里,key是列名,value就是对应的值。

    MapListHandler:将结果集中的每一行数据都封装到一个Map里,然后再存放到List

    5.代码示例

    1.JdbcUtils

    package Utils;

    import java.sql.*;

    /**

    * 1. 返回连接 2. 关闭

    *

    * @author dan.dan

    *

    */

    public class JdbcUtils {

    // 连接参数

        // private String url = "jdbc:mysql://localhost:3306/jdbc_demo";

        private static Stringurl ="jdbc:mysql://10.9.1.43:3306/dandan_test";

    private static Stringuser ="root";

    private static Stringpassword ="123456";

    /**

        * 返回连接对象

        */

        public static Connection getConnection() {

    try {

    Class.forName("com.mysql.jdbc.Driver");

    return DriverManager.getConnection(url,user,password);

    }catch (Exception e) {

    throw new RuntimeException(e);

    }

    }

    /**

        * 关闭

        */

        public static void closeAll(Connection con, Statement stmt, ResultSet rs) {

    try {

    if (rs !=null) {

    rs.close();// 快速异常捕获Alt + shift + z

                    rs =null;// 建议垃圾回收期回收资源

                }

    if (stmt !=null) {

    stmt.close();

    stmt =null;

    }

    if (con !=null && !con.isClosed()) {

    con.close();

    con =null;

    }

    }catch (SQLException e) {

    throw new RuntimeException(e);

    }

    }

    }

    package d_dbUtils;

    public class Admin {

    private int id;

    private Stringuserid;

    private Stringcn_score;

    private Stringmath_score;

    private Stringen_score;

    private Stringpo_score;

    public void setUserid(String userid) {

    this.userid = userid;

    }

    public void setCn_score(String cn_score) {

    this.cn_score = cn_score;

    }

    public void setMath_score(String math_score) {

    this.math_score = math_score;

    }

    public void setEn_score(String en_score) {

    this.en_score = en_score;

    }

    public void setPo_score(String po_score) {

    this.po_score = po_score;

    }

    public String getUserid() {

    return userid;

    }

    public String getCn_score() {

    return cn_score;

    }

    public String getMath_score() {

    return math_score;

    }

    public String getEn_score() {

    return en_score;

    }

    public String getPo_score() {

    return po_score;

    }

    public int getId() {

    return id;

    }

    public void setId(int id) {

    this.id = id;

    }

    @Override

        public String toString() {

    return "Admin [id=" +id +", userid=" +userid +", " +

    "cn_score=" +cn_score +"," +

    "math_score=" +math_score +"," +

    "en_score=" +en_score +"," +

    "po_score=" +po_score +"]";

    }

    }

    package d_dbUtils;

    import Utils.JdbcUtils;

    import org.apache.commons.dbutils.QueryRunner;

    import org.apache.commons.dbutils.ResultSetHandler;

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

    import org.junit.Test;

    import java.sql.Array;

    import java.sql.Connection;

    import java.sql.ResultSet;

    import java.sql.SQLException;

    import java.util.Arrays;

    import java.util.List;

    import java.util.Map;

    import java.util.Set;

    public class App_query {

    private Connectionconn;

    // 一、查询, 自定义结果集封装数据

        @Test

        public void testQuery()throws Exception {

    String sql ="select * from tb_score1 where id=?";

    // 获取连接

            conn = JdbcUtils.getConnection();

    // 创建DbUtils核心工具类对象

            QueryRunner qr =new QueryRunner();

    // 查询

            Admin admin = qr.query(conn, sql,new ResultSetHandler() {

    // 如何封装一个Admin对象

                public Admin handle(ResultSet rs)throws SQLException {

    if (rs.next()) {

    Admin admin =new Admin();

    admin.setId(rs.getInt("id"));

    admin.setUserid(rs.getString("userid"));

    admin.setCn_score(rs.getString("cn_score"));

    return admin;

    }

    return null;

    }

    },29);

    // 测试

          System.out.println(admin);

    // 关闭

          conn.close();

    }

    // 二、查询, 使用组件提供的结果集对象封装数据

            // 1)BeanHandler: 查询返回单个对象

        @Test

        public void testQueryOne()throws Exception {

    String sql ="select * from tb_score1 where id=?";

    // 获取连接

            conn = JdbcUtils.getConnection();

    // 创建DbUtils核心工具类对象

            QueryRunner qr =new QueryRunner();

    // 查询返回单个对象

            Admin admin =  qr.query(conn, sql,new BeanHandler(Admin.class),30);

    System.out.println(admin);

    conn.close();

    }

    // 2)BeanListHandler: 查询返回list集合,集合元素是指定的对象

        @Test

        public void testQueryMany()throws Exception {

    String sql ="select * from tb_score1";

    conn = JdbcUtils.getConnection();

    QueryRunner qr =new QueryRunner();

    // 查询全部数据

            List list = qr.query(conn, sql,new BeanListHandler(Admin.class));

            conn.close();

    }

    @Test

    // 3) ArrayHandler, 查询返回结果记录的第一行,封装对对象数组, 即返回:Object[]

    // 4) ArrayListHandler, 把查询的每一行都封装为对象数组,再添加到list集合

    // 5) ScalarHandler 查询返回结果记录的第一行的第一列  (在聚合函数统计的时候用)

    // 6) MapHandler  查询返回结果的第一条记录封装为map

      public void testArray()throws Exception {

    String sql ="select * from tb_score1";

    conn = JdbcUtils.getConnection();

    QueryRunner qr =new QueryRunner();

    // 查询

          Object[] obj = qr.query(conn, sql,new ArrayHandler());

    System.out.println("数组:"+ Arrays.toString(obj));

    List list = qr.query(conn, sql,new ArrayListHandler());

    for (int i =0; i < list.size(); i++) {

    System.out.println("list:"+ Arrays.toString(list.get(i)));

    } //查询的结果先是数组,然后将数组添加到list中,所以由list获取的每一条都为数组,然后遍历数组才能获取值

    Integer num = qr.query(conn, sql,new ScalarHandler());

    System.out.println("第一列:" + num);

    Map map = qr.query(conn,sql,new MapHandler());

    Set<Map.Entry<String, Object>> entrys = map.entrySet();

    // entry代表一个键值对

            for (Map.Entry entry : entrys) {

    System.out.println("map " + entry.getKey() +"=" + entry.getValue());

    }

    conn.close();

    }

    }

    6.小结

    使用dbutils简化了jdbc编码的工作量,不再用JDBC编写原子性代码,直接使用QueryRunner获取结果,而且其安全性较高,内部的JDBC一些工作已经做好了实现,用户只需直接使用即可。

    相关文章

      网友评论

          本文标题:commons-dbutils工具介绍及实战

          本文链接:https://www.haomeiwen.com/subject/avcfchtx.html