一、什么是Dbutils?
Commons DbUtils是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能。来源百度百科
简而言之,Dbutils就是封装了jdbc的代码,简化了jdbc的dao层的操作。
二、Dbutils的使用
A:导入相关的依赖jar包
mysql-connector-java-5.1.7-bin.jar
commons-dbutils-1.7.jar
B:项目结构
StudentDao接口:对Student实体类对象操作的接口,使用接口利于维护
StudentDaoImpl:StudentDao接口的实现类,用于写具体的功能实现代码
Student类:学生实体类对象,用于封装学生对象的相关属性信息
Test类:功能测试类,用于测试功能实现的代码
JDBCTools:对于JDBC的初步封装的工具类,用于获取数据库连接以及释放资源等操作
db-config.properties文件:用于存储数据库的连接的一些信息,防止硬编码格式,方便更改
C:使用Dbutils的具体步骤
a:创建QueryRunner对象
QueryRunner queryRunner = new QueryRunner();
b:调用QueryRunner对象的方法执行相关操作,给QueryRunner对象传递参数:connection,sql,具体的策略对象;,条件参数
public voidinsert(Student student) {
sql= "insert into student(name,clazz,grade) values(?,?,?)";try{//JDBCTools.getConnection():数据库连接//sql:数据库查询sql语句//student.getName():需要的参数,参数与sql中的参数的数量保持一致
queryRunner.update(JDBCTools.getConnection(),sql,student.getName(),student.getClazz(),student.getGrade());
}catch(SQLException e) {
e.printStackTrace();
}
}
public Student findById(intid) {
sql= " select * from student where id = ?";
Student student= null;try{
student= queryRunner.query(JDBCTools.getConnection(),sql,new BeanHandler(Student.class),id);
}catch(SQLException e) {
e.printStackTrace();
}returnstudent;
}
策略对象
BeanHandler:把单行的结果集封装成javabean对象,返回值是ResultSetHandler,该方法用于将单行结果集封装成javabean对象,对象是通过反射完成创建的
ResultSetHandler rsh = new BeanHandler(javabean.class);
BeanListHandler:将多行结果集封装成对象,并将对象添加到list集合中
List list = > new BeanListHandler(javaBean.class);
MapHandler:将单行的结果集封装到一个map集合中,map集合中的建是表中的列名称,值对应表的列值。
Map map = new MapHandler();
MapListHandler:用于多行结果集的处理,把每行的结果封装成一个map,最后把所有的map都放到一个集合中,返回的是一个list集合,list集合中存放的是map集合。
List> listmap = new MapListHandler();
ColumnHandler:本方法用于互殴去单列,单行或者多行的数据
List nameList = new ColumnHandler();
ScalarHandler:用户处理单行、单列的数据,多用于聚合函数的查询。注意:当聚合函数涉及到数字类型的时候,要注意返回值类型的转换,若使用Integer或者Long类型的时候,容易出现数据无法存储的时候,所以使用Number(这个是所有数字数据类型的父类),对外提供了Number.intValue()和Number.longValue()等方法。
ResultSetHandler resultSetHandler = new ScalarHandler();
C:具体的实现代码
a:JavaBean对象
packagecom.dreambamboo.entity;public classStudent {private intid;privateString name;privateString grade;privateString clazz;public Student(intid, String name, String grade, String clazz) {this.id =id;this.name =name;this.grade =grade;this.clazz =clazz;
}publicStudent() {
}public intgetId() {returnid;
}public void setId(intid) {this.id =id;
}publicString getName() {returnname;
}public voidsetName(String name) {this.name =name;
}publicString getGrade() {returngrade;
}public voidsetGrade(String grade) {this.grade =grade;
}publicString getClazz() {returnclazz;
}public voidsetClazz(String clazz) {this.clazz =clazz;
}publicStudent(String name, String grade, String clazz) {this.name =name;this.grade =grade;this.clazz =clazz;
}
@OverridepublicString toString() {return "Student{" +
"id=" + id +
", name=‘" + name + ‘‘‘ +
", grade=‘" + grade + ‘‘‘ +
", clazz=‘" + clazz + ‘‘‘ +
‘}‘;
}
}
b:dao接口
packagecom.dreambamboo.dao;importcom.dreambamboo.entity.Student;importjava.util.List;public interfaceStudentDao {/*** 添加学生信息
*@paramstudent*/
public voidinsert(Student student);/*** 更新学生信息
*@paramstudent*/
public voidupdate(Student student);/*** 删除学生信息
*@paramid*/
public void delete(intid);/*** 根据学生编号查询学生信息
*@paramid
*@return
*/
public Student findById(intid);/*** 查询所有学生信息
*@return
*/
public ListfindAll();/*** 查询学生总数
*@return
*/
public intstudentCount();
}
c:dao接口实现类
packagecom.dreambamboo.dao.impl;importcom.dreambamboo.dao.StudentDao;importcom.dreambamboo.entity.Student;importcom.dreambamboo.util.JDBCTools;importorg.apache.commons.dbutils.QueryRunner;importorg.apache.commons.dbutils.ResultSetHandler;importorg.apache.commons.dbutils.handlers.BeanHandler;importorg.apache.commons.dbutils.handlers.BeanListHandler;importorg.apache.commons.dbutils.handlers.ScalarHandler;importjava.sql.SQLException;importjava.util.List;public class StudentDaoImpl implementsStudentDao {private QueryRunner queryRunner = null;//查询运行器
publicStudentDaoImpl(){
queryRunner= newQueryRunner();
}
String sql= null;
@Overridepublic voidinsert(Student student) {
sql= "insert into student(name,clazz,grade) values(?,?,?)";try{//JDBCTools.getConnection():数据库连接//sql:数据库查询sql语句//student.getName():需要的参数,参数与sql中的参数的数量保持一致
queryRunner.update(JDBCTools.getConnection(),sql,student.getName(),student.getClazz(),student.getGrade());
}catch(SQLException e) {
e.printStackTrace();
}
}
@Overridepublic voidupdate(Student student) {
sql= " update student set name = ? ,clazz = ?,grade = ? where id = ?";try{
queryRunner.update(JDBCTools.getConnection(),sql,student.getName(),student.getClazz(),student.getGrade(),student.getId());
}catch(SQLException e) {
e.printStackTrace();
}
}
@Overridepublic void delete(intid) {
sql= "delete from student where id = ?";try{
queryRunner.update(JDBCTools.getConnection(),sql,id);
}catch(SQLException e) {
e.printStackTrace();
}
}
@Overridepublic Student findById(intid) {
sql= " select * from student where id = ?";
Student student= null;try{
student= queryRunner.query(JDBCTools.getConnection(),sql,new BeanHandler(Student.class),id);
}catch(SQLException e) {
e.printStackTrace();
}returnstudent;
}
@Overridepublic ListfindAll() {
sql= "select * from student";
List list = null;try{
list= queryRunner.query(JDBCTools.getConnection(),sql,new BeanListHandler<>(Student.class));
}catch(SQLException e) {
e.printStackTrace();
}returnlist;
}
@Overridepublic intstudentCount() {
sql= "select count(id) from student";int count = 0;try{
count= queryRunner.query(JDBCTools.getConnection(),sql,new ScalarHandler());
}catch(SQLException e) {
e.printStackTrace();
}returncount;
}
}
d:数据库接口连接工具类
packagecom.dreambamboo.util;import java.sql.*;importjava.util.ResourceBundle;/*** 数据库操作工具类*/
public classJDBCTools {private staticString URL;private staticString USERNAME;private staticString PASSWORD;private staticString DRIVER;private static ResourceBundle resourceBundle = ResourceBundle.getBundle("com.dreambamboo.util.db-config");privateJDBCTools(){
}/*** 使用静态代码块加载驱动程序
* 防止重复代码,使用静态代码块在类加载的时候只会执行一次*/
static{
URL= resourceBundle.getString("jdbc.url");
USERNAME= resourceBundle.getString("jdbc.username");
PASSWORD= resourceBundle.getString("jdbc.password");
DRIVER= resourceBundle.getString("jdbc.driver");
}/*** 获取数据库连接
*@return
*/
public staticConnection getConnection(){
Connection connection= null;try{
connection=DriverManager.getConnection(URL,USERNAME,PASSWORD);
}catch(SQLException e) {
e.printStackTrace();
System.out.println("获取连接失败");
}returnconnection;
}/*** 关闭数据库连接资源
*@paramconnection 数据库连接
*@paramstatement 数据库会话语句
*@paramresultSet 数据库查询结果集*/
public static voidrelease(Connection connection, Statement statement, ResultSet resultSet){try{if (connection != null) {
connection.close();
}if (statement != null) {
statement.close();
}if (resultSet != null) {
resultSet.close();
}
}catch(SQLException e) {
e.printStackTrace();
}
}
}
e:数据库配置文件
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.username=root
jdbc.password=mysql
jdbc.driver=com.mysql.jdbc.Driver
f:测试代码
packagecom.dreambamboo.test;importcom.dreambamboo.dao.StudentDao;importcom.dreambamboo.dao.impl.StudentDaoImpl;importcom.dreambamboo.entity.Student;importjava.util.List;public classTest {public static voidmain(String[] args) {
StudentDao studentDao= newStudentDaoImpl();//studentDao.insert(new Student("孙悟空","高三年级","五班"));//studentDao.update(new Student(14,"孙悟空111","高三年级","十一班"));//studentDao.delete(14);
List list =studentDao.findAll();for(Student st : list) {
System.out.println(st.getId()+ "===>>>" + st.getName() + "===>>>>" + st.getClazz() + "===>>> "+st.getGrade());
}
}
}
三、自定义的Dbutils工具类