DBUtils工具类

1.DBUtils工具类,由apache组织提供的工具类,对JDBC做了一些简单封装。
   做了查询的封装,把查询的结果封装到List集合 Map集合 JavaBean对象中
做了增删改的封装,编写代码比较少 2.需要导入开发的jar包
commons-dbutils-1.4.jar


3.常见的
QueryRunner
  1.QueryRunner类可以来完成增删改查所有的功能

  2.常用的方法    

     QueryRunner()                                                 -- 构造方法,没有任何参数,说明他不管理连接的。
     QueryRunner(DataSource ds)                                    -- 构造方法,传入连接池,说明他已经管理连接(从连接池中获取连接,归还连接)

     int update(String sql, Object... params)                      -- 连接已经管理了
int update(Connection conn, String sql, Object... params) -- 说明连接没有管理 <T> T query(String sql, ResultSetHandler<T> rsh, Object... params)
<T> T query(Connection conn, String sql, ResultSetHandler<T> rsh, Object... params) int [] batch(String sql, Object[][] params) -- 批处理的方法(批量执行一些SQL语句)new Object[][]{{xx},{yy}}

4.常见的ResultSetHandler接口  
  1.ResultSetHandler接口,提供了一个方法,让用户自己来封装结果集。
  2.接口中提供了9个实现类,封装结果集的类型都是不同的
   BeanHandler -- 把一条记录封装到一个JavaBean的对象中。
  BeanListHandler -- 把一条记录封装到一个JavaBean对象中,再把这些JavaBean封装到一个List集合中。List<JavaBean>   ArrayHandler -- 把一条记录封装到一个数组中
  ArrayListHandler -- 把一条记录封装到一个数组中,把这些数组封装到List集合中    MapHandler -- 把一条记录封装到Map集合中
   MapListHandler -- 把一条记录封装到Map集合中,这些map封装到List集合中    ColumnListHandler -- 查询的是某列的数据(select username from t_account),把该列封装到List集合中    KeyedHandler -- 把一条记录封装到Map集合中,再把这些map封装到一个大的map集合中   ScalarHandler -- 封装的是聚集函数(count sum avg max min)

 例子:

    重写Java ee_02版本增删检查方法:

    重写前的UserDaoImpl类:

package org.Impl;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.KeyedHandler;
import org.dao.UserDao;
import org.model.User;
import org.util.DBUtil; /**
*
* @author H_Pioneer
* 接口实现类
*/ public class UserDaoImpl implements UserDao{
@Override
// 定义添加方法
public boolean addUser(User u) { boolean flag=false;
Connection conn=null;
PreparedStatement pst=null; try{
conn=DBUtil.getConnection();
String sql="insert into user (username,password) values(?,?)";
pst=conn.prepareStatement(sql); pst.setString(1, u.getName());
pst.setString(2, u.getPassword()); int rows= pst.executeUpdate(); if (rows > 0){
flag=true;
}
}catch(Exception ex){
ex.printStackTrace();
}finally{
DBUtil.closeResource(conn, pst);
}
return flag; } @Override
public User getUserByName(String username) {
Connection conn = null;
Statement st = null;
ResultSet rs = null;
User u = new User();
String sql = "select * from user where username ="+"'"+username+"'"; try {
conn = DBUtil.getConnection();
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} try { st = conn.createStatement();
rs = st.executeQuery(sql); while(rs.next()){
u.setName(rs.getString("username"));
u.setPassword(rs.getString("password"));
}
} catch (SQLException e) {
e.printStackTrace();
}finally{
DBUtil.closeResource(conn,st,rs);
}
return u; } @Override
public boolean checkLogin(String username, String password) { boolean flag = false;
User u = new User();
u = getUserByName(username); if(u.getPassword().equals(password)) {
flag = true;
}
return flag;
}
}

    重写后的UserDaoImpl类:

package org.Impl;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.ResultSetHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.KeyedHandler;
import org.dao.UserDao;
import org.model.User;
import org.util.DBUtil; import com.mchange.v2.c3p0.ComboPooledDataSource; public class IUserDaoImpl implements UserDao { @Override
public boolean addUser(User u) { boolean flag = false; QueryRunner runner = new QueryRunner(DBUtil.getDataSource()); String sql="insert into user (username,password) values(?,?)"; try { int rows = runner.update(sql , new String[]{u.getName(),u.getPassword()});
if (rows > 0){
flag=true;
} } catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return flag;
} @Override
public User getUserByName(String username) {
User u= new User(); QueryRunner runner = new QueryRunner(DBUtil.getDataSource()); String sql = "select * from user where username =?"; try { u = runner.query(sql, new BeanHandler<User>(User.class),username ); } catch (SQLException e) { e.printStackTrace();
}
return u;
} @Override
public boolean checkLogin(String username, String password) {
boolean flag = false;
User u = new User();
u = getUserByName(username); if(u.getPassword().equals(password)) {
flag = true;
}
return flag;
}
}
 
 

DBUtils工具类的使用的更多相关文章

  1. Java学习笔记49(DBUtils工具类二)

    上一篇文章是我们自己模拟的DBUtils工具类,其实有开发好的工具类 这里使用commons-dbutils-1.6.jar 事务的简单介绍: 在数据库中应用事务处理案例:转账案例 张三和李四都有有自 ...

  2. Java基础-DButils工具类(QueryRunner)详解

    Java基础-DButils工具类(QueryRunner)详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC ...

  3. 30_java之DButils工具类

    01DButils工具类的介绍个三个核心类 * A: DButils工具类的介绍个三个核心类 * a: 概述 * DBUtils是java编程中的数据库操作实用工具,小巧简单实用. * DBUtils ...

  4. DBUtils工具类和DBCP连接池

    今日内容介绍 1.DBUtils2.处理结果集的八种方式3.连接池4.连接池的用法1 PrepareStatement接口预编译SQL语句 1.1 预处理对象 * 使用PreparedStatemen ...

  5. java使用dbutils工具类实现小程序 管家婆记账软件

    1.所需创建的包和 jar包 2.创建表结构  #生成一些表数据 ,,'交通银行','2016-03-02','家庭聚餐'); ,,'现金','2016-03-15','开工资了'); ,,'现金', ...

  6. 【知了堂学习心得】浅谈c3p0连接池和dbutils工具类的使用

    1. C3P0概述 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等. 2. C3P ...

  7. dbutils工具类使用

    1DBUtils工具类 1.1概述 DBUtils是java编程中的数据库操作实用工具,小巧简单实用. DBUtils封装了对JDBC的操作,简化了JDBC操作,可以少写代码 DBUtils三个核心功 ...

  8. DBUtils工具类学习一

    Commons DbUtils是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响程序的性能 1.特征 DBUtils是java编程中 ...

  9. Java学习笔记48(DBUtils工具类一)

    上一篇的例子可以明显看出,在增删改查的时候,很多的代码都是重复的, 那么,是否可以将增删改查封装成一个类,方便使用者 package demo; /* * 实现JDBC的工具类 * 定义方法,直接返回 ...

随机推荐

  1. MyBatis 一级缓存避坑

    MyBatis 一级缓存(MyBaits 称其为 Local Cache)无法关闭,但是有两种级别可选: package org.apache.ibatis.session; /** * @autho ...

  2. vmware开发包之vSphere Management SDK

    vSphere Management SDK关于vmware管理等相关功能的.net和java的代码示例. 在其5.5的解压包中 eam:esx agent management表示esx虚机生产环境 ...

  3. robotframework+jenkins分布式执行自动化测试用例

    http://blog.sina.com.cn/s/blog_53f023270101sc3w.html http://www.cnblogs.com/2test/p/5336842.html

  4. POJ - 1251A - Jungle Roads 利用最小生成树

    The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign aid money was s ...

  5. 读取xml文件内容到数据库

    前言 前言不搭后语·················· 内容 听某个大牛说他们的公司常常会涉及到从xml文件中读数据到写入到数据库,序列化的时候会遇到这这个问题,将要持久化的数据到xml文件存储起来, ...

  6. kali linux之msf客户端渗透

    在无法通过网络边界的情况下转而攻击客户端----进行社会工程学攻击,进而渗透线上业务网络 含有漏洞利用代码的web站点--利用客户端漏洞 含有漏洞利用代码的doc,pdf等文档----诱使被害者执行p ...

  7. 【sonar-block】Use try-with-resources or close this "BufferedInputStream" in a "finally" clause.

    自己的理解: try-with-resources是JDK7的新语法结构,主要功能是自动关闭资源而不需要在finally里面手动close()关闭, 而且最重要的是,try块中的异常不会被close( ...

  8. HDU6333-2018ACM暑假多校联合训练1002-Harvest of Apples-莫队+费马小定理

    题意很简单啦,求S(n,m)的值 通过打表我们可以知道 S(n + 1, m) = S(n, m) * 2 - C(n, m); S(n - 1, m) = (S(n, m) + C(n - 1, m ...

  9. SSO单点登录入门

    1,SSO简介 SSO(Single Sign-On,单点登录)是身份管理中的一部分.SSO 的一种较为通俗的定义是:SSO 是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过 ...

  10. MVC模式学习--雇员管理系统项目开发

    1, 项目开发,使用原型开发, ① 开发流程: 需求分析->设计阶段->编码阶段->测试阶段->发布阶段/维护阶段 需求阶段:PM/项目经理 对客户 设计阶段:技术人员(架构师 ...