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();
}
}