// Jdbc 的增,删, 改流程类似,只是参数不同, 因此可以向上抽取
public class Demo{ // Jdbc 的增加
public void addStu(Stu stu){ Connection con = null;
PreparedStatement pstmt = null;
try{
con = JdbcUtils.getConnection();
String sql = "INSERT INTO t_stu VALUES(?,?,?,?)";
pstmt = con.prepareStatement(sql); pstmt.setInt(1,stu.getSid());
pstmt.setString(2,stu.getSname());
pstmt.setInt(3,stu.getAge());
pstmt.setString(4,stu.getGender()); pstmt.executeUpdate();
} catch(Exception e){
// 处理异常
} finally{
// 关闭资源
}
} // jdbc 修改方法
public void UpdateStu(Stu stu){ Connection con = null;
PreparedStatement pstmt = null;
try{
con = JdbcUtils.getConnection();
// 只需要 sql 语句修改
String sql = "UPDATE t_stu SET sname=?,age=?,gender=? WHERE sid=?";
pstmt = con.prepareStatement(sql); pstmt.setInt(4,stu.getSid());
pstmt.setString(1,stu.getSname());
pstmt.setInt(2,stu.getAge());
pstmt.setString(3,stu.getGender()); pstmt.executeUpdate();
} catch(Exception e){
// 处理异常
} finally{
// 关闭资源
}
} // jdbc 删除方法
public void UpdateStu(int sid){ Connection con = null;
PreparedStatement pstmt = null;
try{
con = JdbcUtils.getConnection();
// 只需要 sql 语句修改
String sql = "DELETE FROM t_stu WHERE sid=?";
pstmt = con.prepareStatement(sql); pstmt.setInt(1,stu.getSid()); pstmt.executeUpdate();
} catch(Exception e){
// 处理异常
} finally{
// 关闭资源
}
} // jdbc 的查询方法 (查询一个)
public Stu load(int sid){ Connection con = null;
PreparedStatement pstmt = null;
ResultSetHandler rs = null;
try{
con = JdbcUtils.getConnection();
// 只需要 sql 语句修改
String sql = "SELECT * FROM t_stu WHERE sid=?";
pstmt = con.prepareStatement(sql); pstmt.setInt(1,stu.getSid()); // 发送 sql 语句需要变化
rs = pstmt.executeQuery(); if(!rs.next()) return null; // 需要把 rs 转换成 Stu 对象
Stu stu = new Stu();
stu.setSid(rs.getInt("sid"));
stu.setSname(rs.getString("sname"));
stu.setAge(rs.getInt("age"));
stu.setGender(rs.getString("gender")); return stu;
} catch(Exception e){
// 处理异常
} finally{
// 关闭资源
}
}
} // 升级
public class QR<T>{ private DataSource dataSource; // 构造函数
public QR(DataSource dataSource){
super();
this.dataSource = dataSource;
} // 无参构造函数
public QR(){
super();
} // 可以实现数据库的 insert,update, delete
public int update(String sql, Object... params){
Connection con = null;
PreparedStatement pstmt = null;
try{
con = dataSource.getConnection(); pstmt = con.prepareStatement(sql);
initParams(pstmt, params); // 设置参数 // 返回影响的行数
return pstmt.executeUpdate();
} catch(Exception e){
throw new RuntimeException(e);
} finally{
// 关闭资源
try{
if(pstmt != null) pstmt.close();
if(con != null) con.close();
} catch(SQLException e){
throw new RuntimeException(e);
}
}
} // 私有方法, 专门给 sql 语句的参数赋值
private void initParams(PreparedStatement pstmt, Object... params)
throws SQLException{ // 循环遍历赋值
for(int i=0; i<params.length; i++){
pstmt.setObject(i+1, params[i]);
}
} // 查询方法
public T query(String sql, RsHandler rh, Object... params){
Connection con = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try{
con = dataSource.getConnection(); pstmt = con.prepareStatement(sql);
initParams(pstmt,params); rs = pstmt.executeQuery(); return (T)rh.handle(rs); }catch(Exception e){
throw new RuntimeException(e);
} finally{
try{
if(pstmt != null) pstmt.close();
if(con != null) con.close();
} catch(SQLException e){
throw new RuntimeException(e);
}
}
}
} // 接口, 将 ResultSet 转换成 JavaBean 实体
interface RsHandler<T>{
public T handle(ResultSet rs) throws SQLException;
} // 使用上述 QR 类操作数据库
public class Demo2{ public void fun(){
Stu stu = new Stu(1001,"lisi",22,"male"); addStu(stu);
} // 添加操作
public void addStu(Stu stu){
// 创建对象时, 给出连接池
QR qr = new QR(JdbcUtils.getDataSource()); // 给出 sql 模板
String sql = "INSERT INTO t_stu VALUES(?,?,?,?)"; // 给出参数
Object[] params = {stu.getSid(),stu.getSname(),stu.getAge(),stu.getGender()}; // 调用 QR 类的 update 方法
qr.update(sql,params);
} // 查询操作
public Stu load(int sid){
QR qr = new QR(JdbcUtils.getDataSource()); String sql = "SELECT * FROM WHERE sid=?";
Object[] params = {sid}; // 实现 RsHandler 接口,
// 可以将 ResultSet 结果集转换为 Stu 对象
RsHandler<Stu> rh = new RsHandler<Stu>(){
// 实现方法
public Stu handle(ResultSet rs) throws SQLException {
if(!rs.next()) return null;
Stu stu = new Stu();
stu.setSid(rs.getInt("sid"));
stu.setSname(rs.getString("sname"));
stu.setAge(rs.getInt("age"));
stu.getGender(rs.getString("gender")); return stu;
} }; qr.query(sql,rh,params);
}
}

DBUtils 工具类的使用

public class Demo(){

    // 数据库添加数据
public void fun1() throws SQLException{
// 给出连接池参数
QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource()); // 给出 sql 模板
String sql = "INSERT INTO t_stu VALUES(?,?,?,?)"; // 给出参数的值
Object[] params = {1003,"zhaoliu",24,"male"}; qr.update(sql,params);
} // 数据库查询
public void fun2() throws SQLException{
// 给出连接参数
QueryRunner qr = new QueryRunner(JdbcUtils.getDataSource()); // 给出 sql 模板
String sql ="SELECT * FROM t_stu WHERE sid=?"; // 传入参数
Object[] params = {1003}; // 执行query() 方法, 需要给出结果集处理器, 即 ResultSetHandler 的实现类.
// ResultHandler 实现类也就是将 ResultSet 结果集转换为 Stu 对象
Stu stu = qr.query(sql,new BeanHandler<Stu>(Stu.class),params); System.out.println(stu);
}
}

参考资料:

dbUtils 原理的更多相关文章

  1. DbUtils要点小结

    一. DbUtils核心API 1. QueryRunner update方法 query方法 2. 各种Handler都实现ResultSetHandler接口 beanhandler beanli ...

  2. python数据库连接池设计

    一.背景: 传统访问资源,一般分为一下几个步骤: 1.实例数据驱动对象与链接资源.2.实例操作资源游标.3.获取资源.4.关闭链接资源. 根据以上步骤,我们可以很简单使用这个原始方法来访问资源为我们业 ...

  3. Junit 注解 类加载器 .动态代理 jdbc 连接池 DButils 事务 Arraylist Linklist hashset 异常 哈希表的数据结构,存储过程 Map Object String Stringbufere File类 文件过滤器_原理分析 flush方法和close方法 序列号冲突问题

    Junit 注解 3).其它注意事项: 1).@Test运行的方法,不能有形参: 2).@Test运行的方法,不能有返回值: 3).@Test运行的方法,不能是静态方法: 4).在一个类中,可以同时定 ...

  4. 模拟实现 DBUtils 工具 , 技术原理浅析

    申明:本文采用自己 C3P0 连接池工具进行测试 自定义的 JDBCUtils 可以获取 Connection: package com.test.utils; import java.sql.Con ...

  5. 【Java EE 学习 52】【Spring学习第四天】【Spring与JDBC】【JdbcTemplate创建的三种方式】【Spring事务管理】【事务中使用dbutils则回滚失败!!!??】

    一.JDBC编程特点 静态代码+动态变量=JDBC编程. 静态代码:比如所有的数据库连接池 都实现了DataSource接口,都实现了Connection接口. 动态变量:用户名.密码.连接的数据库. ...

  6. Atitit.木马病毒websql的原理跟个设计

    Atitit.木马病毒websql的原理跟个设计 1. Keyword Wsql { var sql="select "+p.txt+" as t,"+p.v+ ...

  7. 内存缓存LruCache实现原理

    自己项目中一直都是用的开源的xUtils框架,包括BitmapUtils.DbUtils.ViewUtils和HttpUtils四大模块,这四大模块都是项目中比较常用的.最近决定研究一下xUtils的 ...

  8. 分享动态拼接Expression表达式组件及原理

    前言 LINQ大家都知道,用起来也还不错,但有一个问题,当你用Linq进行搜索的时候,你是这样写的 var query = from user in db.Set<User>()      ...

  9. java web简易网上书店项目系列,使用MVC模式(servlet+jstl+dbutils),开篇

    一. 针对很多java web初学者入门困难的问题,笔者利用一个小型web项目,一步一步的展示java web开发方法,每一个章节引入一些java web开发的重点知识,让同学们可以将java web ...

随机推荐

  1. lucene 索引中文档的属性建立与不建立带来的影响总结

    索引中文档的属性建立与不建立带来的影响总结   1.依据文档的某属性去查找索引的话,只会返回带有此属性(如果你对当前属性设定了条件,那么需要满足当前条件)的所有文档,没有建立此属性的文档是不会在返回结 ...

  2. 【MyBatis学习08】高级映射之一对一查询

    从这一篇博文开始,将总结一下mybatis中的几个高级映射,即一对一.一对多.多对多查询,这篇先总结一下mybatis中的一对一查询.  为了模拟这些需求,事先要建立几个表,不同的表之间将对应上面提到 ...

  3. 在VS2013 IIS Express 添加MIME映射

    打开VS2013返回json提示MIME映射问题 1.在DOS窗口下进入IIS Express安装目录,默认是C:\Program Files\IIS Express,cmd  命令行cd 到 该目录 ...

  4. MySQL学习总结(三)索引

    补充一下,上一章节中约束的一点东西.我们在为约束设置名称的时候(标识符)推荐写法“约束缩写_字段名”,这样让人看起来就会很清晰.例如:FK_Deptno,我们通过索引的名字就可以大概知道这是一个设置的 ...

  5. Nginx 0.8.x + PHP 5.2.13(FastCGI)搭建胜过Apache十倍的Web服务器(第6版)(转)

    转自:http://blog.s135.com/nginx_php_v6/] 前言:本文是我撰写的关于搭建“Nginx + PHP(FastCGI)”Web服务器的第6篇文章.本系列文章作为国内最早详 ...

  6. atitit.复合变量,也就是类似$$a的变量的原理与实现 java c#.net php js

    atitit.复合变量,也就是类似$$a的变量的原理与实现 java c#.net php js 1.1. 复合变量,也就是类似$$a的变量,它会进行两次的解释. 1 1.2. 数据库里面的复合变量1 ...

  7. C++语言基础(4)-构造函数和析构函数

    一.构造函数 类似于java,C++中也有构造函数的概念,相关用法如下: 1.1 构造函数的定义 #include <iostream> using namespace std; clas ...

  8. 服务器中很多的CLOSE_WAIT

    服务器中很多的CLOSE_WAIT,请教各位大虾!!!!!!!!!最近遇到一个问题,工程在LINUX服务器上面跑起来了以后,运行一段时间 就有很多的CLOSE_WAIT链接,多了之后,网站就访问不了了 ...

  9. php类库PHP QR Code 二维码

    php类库PHP QR Code 二维码 php类库PHP QR Code 二维码 php类库PHP QR CodePHP QR Code is open source (LGPL) library ...

  10. layui表格的批量删除功能

    // 批量删除功能 // 1.得到table选中行内容 // 2.得到删除需要的唯一值,一般是id; // 3.将所要删除的项加入到数组中: // 4.判断是否选中: // 5.发送ajax请求,并附 ...