Java

JDBC 使用DBUtils的QueryRunner进行DRUD

2019-12-24  本文已影响0人  一亩三分甜

使用DBUtils的QueryRunner进行增删改(插入)操作

public class QueryRunnerTest {
    //测试插入
    @Test
    public void testInsert() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "insert into customers(name,email,birth)values(?,?,?)";
            int insertCount = runner.update(conn, sql, "张靓颖", "zly@126.com", "1984-10-11");
            System.out.println("添加了" + insertCount + "条记录");
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
}
//输出
十二月 23, 2019 5:25:36 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 23, 2019 5:25:36 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 23, 2019 5:25:37 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
添加了1条记录
WX20191223-173100@2x.png

使用DBUtils的QueryRunner进行查询操作

1.查询单条数据:分别用BeanHandler或MapHandler接收,BeanHandler:是ResultSetHandler接口的实现类,用于封装表中的一条记录。MapHandler:是ResultSetHandler接口的实现类,用于封装表中的一条记录。将字段及相应字段的值作为map中的key和value。

    //测试查询
    /*
    * BeanHandler:是ResultSetHandler接口的实现类,用于封装表中的一条记录。
    */
    @Test
    public void testQuery() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select id,name,email,birth from customers where id = ?";
            BeanHandler<Customer> beanHandler = new BeanHandler<Customer>(Customer.class);
            Customer customer = runner.query(conn, sql, beanHandler, 9);
            System.out.println(customer);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:28:53 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:28:53 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:28:54 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
Customer{id=9, name='周杰伦', email='zhoujl@sina.com', birth=1979-11-15 00:00:00.0}

    /*
     * MapHandler:是ResultSetHandler接口的实现类,用于封装表中的一条记录。
     * 将字段及相应字段的值作为map中的key和value
     */
    @Test
    public void testQuery2() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select id,name,email,birth from customers where id = ?";
            MapHandler mapHandler = new MapHandler();
            Map<String, Object> map = runner.query(conn, sql, mapHandler, 9);
            System.out.println(map);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:30:52 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:30:54 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:30:54 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
{name=周杰伦, birth=1979-11-15 00:00:00.0, id=9, email=zhoujl@sina.com}

2.查询多条数据:分别用BeanListHandler或MapListHandler接收。BeanListHandler:是ResultSetHandler接口的实现类,用于封装表中的多条记录构成的集合。MapListHandler:是ResultSetHandler接口的实现类,用于封装表中的多条记录。将字段及相应字段的值作为map中的key和value,将这些map添加到list中。

    /*
    * BeanListHandler:是ResultSetHandler接口的实现类,用于封装表中的多条记录构成的集合。
    */
    @Test
    public void testQuery1() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select id,name,email,birth from customers where id < ?";
            BeanListHandler<Customer> beanListHandler = new BeanListHandler<Customer>(Customer.class);
            List<Customer> list = runner.query(conn, sql, beanListHandler, 9);
            list.forEach(System.out::println);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:34:37 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:34:38 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:34:38 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
Customer{id=1, name='汪峰', email='wf@126.com', birth=2010-02-02 00:00:00.0}
Customer{id=2, name='王菲', email='wf@126.com', birth=1988-12-16 00:00:00.0}
Customer{id=4, name='汤唯', email='tw@126.com', birth=1986-05-19 00:00:00.0}
Customer{id=5, name='成龙', email='Jackey@gmail.com', birth=1955-07-14 00:00:00.0}
Customer{id=7, name='刘亦菲', email='liuyifei@qq.com', birth=1991-11-16 00:00:00.0}
Customer{id=8, name='陈道明', email='bdf@126.com', birth=1963-09-16 00:00:00.0}

    /*
     * MapListHandler:是ResultSetHandler接口的实现类,用于封装表中的多条记录。
     * 将字段及相应字段的值作为map中的key和value,将这些map添加到list中
     */
    @Test
    public void testQuery3() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select id,name,email,birth from customers where id < ?";
            MapListHandler mapListHandler = new MapListHandler();
            List<Map<String, Object>> list = runner.query(conn, sql, mapListHandler, 9);
            list.forEach(System.out::println);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:36:09 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:36:09 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:36:09 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
{name=汪峰, birth=2010-02-02 00:00:00.0, id=1, email=wf@126.com}
{name=王菲, birth=1988-12-16 00:00:00.0, id=2, email=wf@126.com}
{name=汤唯, birth=1986-05-19 00:00:00.0, id=4, email=tw@126.com}
{name=成龙, birth=1955-07-14 00:00:00.0, id=5, email=Jackey@gmail.com}
{name=刘亦菲, birth=1991-11-16 00:00:00.0, id=7, email=liuyifei@qq.com}
{name=陈道明, birth=1963-09-16 00:00:00.0, id=8, email=bdf@126.com}

使用DBUtils的QueryRunner查询特殊值:ScalarHandler用于查询特殊值。

    /*
     * ScalarHandler用于查询特殊值
     */
    @Test
    public void testQuery4() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select count(*) from customers";
            ScalarHandler handler = new ScalarHandler();
            Long lon = (Long) runner.query(conn, sql, handler);
            System.out.println(lon);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:55:16 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:55:16 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:55:16 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
18
   @Test
    public void testQuery5() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select max(birth) from customers";
            ScalarHandler handler = new ScalarHandler();
            Date date = (Date) runner.query(conn, sql, handler);
            System.out.println(date);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 5:55:51 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 5:55:51 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 5:55:52 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
2019-12-19 00:00:00.0

自定义ResultSetHandler的实现类

/*
     * 自定义ResultSetHandler的实现类
     */
    @Test
    public void testQuery6() {
        Connection conn = null;
        try {
            QueryRunner runner = new QueryRunner();
            conn = JDBCUtils.getConnection3();
            String sql = "select id,name,email,birth from customers where id = ?";
            ResultSetHandler<Customer> handler = new ResultSetHandler<Customer>() {
                @Override
                public Customer handle(ResultSet resultSet) throws SQLException {

                    if (resultSet.next()){
                        int id = resultSet.getInt("id");
                        String name = resultSet.getString("name");
                        String email = resultSet.getString("email");
                        Date date = resultSet.getDate("birth");
                        Customer customer = new Customer(id,name,email,date);
                        return customer;
                    }
                    return null;
                }
            };
            Customer customer = runner.query(conn, sql, handler,9);
            System.out.println(customer);
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            JDBCUtils.closeResource(conn, null);
        }
    }
//输出
十二月 24, 2019 6:10:47 下午 com.mchange.v2.log.MLog <clinit>
信息: MLog clients using java 1.4+ standard logging.
十二月 24, 2019 6:10:48 下午 com.mchange.v2.c3p0.C3P0Registry banner
信息: Initializing c3p0-0.9.1.2 [built 21-May-2007 15:04:56; debug? true; trace: 10]
十二月 24, 2019 6:10:48 下午 com.alibaba.druid.pool.DruidDataSource info
信息: {dataSource-1} inited
Customer{id=9, name='周杰伦', email='zhoujl@sina.com', birth=1979-11-15}

使用DbUtils类关闭资源

/**
    * @Description: 使用dbutils.jar中提供的DbUtils工具类,实现资源的关闭
    * @Param: 
    * @return: 
    * @Author: fish
    * @Date: 6:25 PM 2019/12/24
    */ 
    public static void closeResource0(Connection conn, Statement ps, ResultSet rs){
//        try {
//            DbUtils.close(conn);
//        } catch (SQLException e) {
//            e.printStackTrace();
//        }
//        try {
//            DbUtils.close(ps);
//        } catch (SQLException e) {
//            e.printStackTrace();
//        }
//        try {
//            DbUtils.close(rs);
//        } catch (SQLException e) {
//            e.printStackTrace();
//        }
        DbUtils.closeQuietly(conn);
        DbUtils.closeQuietly(ps);
        DbUtils.closeQuietly(rs);
    }
上一篇 下一篇

猜你喜欢

热点阅读