使用dbutils完成CURD操作

3 篇文章 0 订阅
1 篇文章 0 订阅

dbutils:

是apache组织的一个工具类,jdbc的框架,更方便我们使用
使用步骤:
    1.导入jar包(commons-dbutils-1.4.jar)
    2.创建一个queryrunner类
        queryrunner作用:操作sql语句
            构造方法:
                new QueryRunner(Datasource ds);
    3.编写sql
    4.执行sql
        query(..):执行r操作
        update(...):执行cud操作

jar包下载commons-dbutils-1.4.jar

核心类或接口

QueryRunner:类名
    作用:操作sql语句
    构造器:
        new QueryRunner(Datasource ds);
    注意:
        底层帮我们创建连接,创建语句执行者 ,释放资源.
    常用方法:
        query(..):
        update(..):

DbUtils:释放资源,控制事务 类
    closeQuietly(conn):内部处理了异常
    commitAndClose(Connection conn):提交事务并释放连接
    ....

ResultSetHandler:封装结果集 接口

     ArrayHandler, ArrayListHandler, BeanHandler, BeanListHandler, ColumnListHandler, KeyedHandler, MapHandler, MapListHandler, ScalarHandler

     (了解)ArrayHandler, 将查询结果的第一条记录封装成数组,返回
     (了解)ArrayListHandler, 将查询结果的每一条记录封装成数组,将每一个数组放入list中返回
     ★★BeanHandler, 将查询结果的第一条记录封装成指定的bean对象,返回
     ★★BeanListHandler, 将查询结果的每一条记录封装成指定的bean对象,将每一个bean对象放入list中 返回.
     (了解)ColumnListHandler, 将查询结果的指定一列放入list中返回 
     (了解)MapHandler, 将查询结果的第一条记录封装成map,字段名作为key,值为value 返回
     ★MapListHandler, 将查询结果的每一条记录封装map集合,将每一个map集合放入list中返回
     ★ScalarHandler,针对于聚合函数 例如:count(*) 返回的是一个Long值

一、使用ArrayHandler进行查询实验

public class CurdUtil {


    private QueryRunner qr = new QueryRunner(MyDataSource.getDataSource());

   public void select(String sql) {
        try {
            Object []obj = qr.query(sql, new ArrayHandler());
            System.out.println(obj[0]);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    public static void main(String[] args) {
        String sql = "select * from user";
        new CurdUtil().select(sql);
    }
}

结果将打印数据库user表中的第一个数据

二、使用BeanHandler进行查询

因为BeanHandler返回的结果集是bean对象,所以需要创建一个bean对象的类
例如我创建了一个Demo.java

package com.sharetime.jdbc.util;

/**
 * @Author: yd
 * @Date: 2018/7/21 16:55
 * @Version 1.0
 */
public class Demo {
    private String PhoneNum;
    private String PetName;



    @Override
    public String toString() {
        return PhoneNum+"---"+PetName;
    }

    public String getPhoneNum() {
        return PhoneNum;
    }

    public void setPhoneNum(String phoneNum) {
        PhoneNum = phoneNum;
    }

    public String getPetName() {
        return PetName;
    }

    public void setPetName(String petName) {
        PetName = petName;
    }
}

其中的两个属性的名字一定要和数据库中的字段保持一致,否则读取不到数据,

重写了toString方法,打印时之间打印两个属性值

测试查询

package com.sharetime.jdbc.util;

import com.sharetime.jdbc.datasource.MyDataSource;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;

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

/**
 * 增删改查的工具类
 *
 * @Author: yd
 * @Date: 2018/7/21 16:47
 * @Version 1.0
 */
public class CurdUtil {


    private QueryRunner qr = new QueryRunner(MyDataSource.getDataSource());

    public void select(String sql) {
        try {
            Demo de = qr.query(sql, new BeanHandler<>(Demo.class));
            System.out.println(de);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
        String sql = "select * from user";
        new CurdUtil().select(sql);
    }
}

打印结果为
18838161573—清风自来
说明打印该数据成功

三、使用BeanListHandler查询数据

BeanListHandler返回的结果是一个list集合,list里面存储的是bean对象,因此用集合来接收显示即可,和BeanHandler操作相同

package com.sharetime.jdbc.util;

import com.sharetime.jdbc.datasource.MyDataSource;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanListHandler;

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

/**
 * 增删改查的工具类
 *
 * @Author: yd
 * @Date: 2018/7/21 16:47
 * @Version 1.0
 */
public class CurdUtil {


    private QueryRunner qr = new QueryRunner(MyDataSource.getDataSource());

    public void select(String sql) {
        try {
            List<Demo> list = qr.query(sql, new BeanListHandler<>(Demo.class));
            System.out.println(list);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    /**
     * 插入数据
     *
     * @param sql
     * @return void
     */
    public void insert(String sql) {
        try {
            qr.update(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
        String sql = "select * from user";
        new CurdUtil().select(sql);
    }
}

四、插入一条数据

 String sql = "insert into user values('18838161574','清风丿自来') ";
 insert(sql);//执行插入方法
/**
     * 插入数据
     *
     * @param sql
     * @return void
     */
    public void insert(String sql) {
        try {
            qr.update(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值