接口 : DAO<T>.java

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

/*
 * 访问数据的DAO接口。
 * @param T:DAO处理的实体类的类型
 * */
public interface DAO<T> {

   /*
    * 批量处理的方法
    * @param con:数据库连接
    * @param sql:SQL语句
    * @param args:填充占位符的Object[]类型的可变参数
    * @return
    * */
   void batch(Connection con,String sql,Object[]...args);
 
   /*
    * 返回具体的一个值,eg.总人数,平均工资。。。
    * @param con:数据库连接
    * @param sql:SQL语句
    * @param args:填充占位符的可变参数
    * @return
    * */
   <E> E getForValue(Connection con,String sql,Object...args);
 
   /*
    * 返回一个T的一个集合
    * @param con:数据库连接
    * @param sql:SQL语句
    * @param args:填充占位符的可变参数
    * @return
    * */
   List<T> getForList(Connection con,String sql,Object...args);
 
   /*
    * 返回一个T的对象
    * @param con:数据库连接
    * @param sql:SQL语句
    * @param args:填充占位符的可变参数
    * @return
    * */
   T get(Connection con,String sql,Object...args) throws SQLException;
 
   /*
    * insert、update、delete
    * @param con:数据库连接
    * @param sql:SQL语句
    * @param args:填充占位符的可变参数
    * */
   void update(Connection con,String sql,Object...args);
}

DAO接口实现类:JdbcDAOImpl.java

import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import com.kk.jdbc.ReflectionUtils;

/*
 * 使用QueryRunner提供其具体的实现
 * @param<T>:子类需要传入泛型的类型
 * */
public class JdbcDAOImpl<T> implements DAO<T> {

   private QueryRunner qr=null;
   private Class<T> type;
 
   public JdbcDAOImpl() {
  
      qr=new QueryRunner();
      type=ReflectionUtils.getSuperGenericType(getClass());
   }
 
   @Override
   public void batch(Connection con, String sql, Object[]... args) {
      // TODO Auto-generated method stub
  
   }

  @Override
   public <E> E getForValue(Connection con, String sql, Object... args) {
      // TODO Auto-generated method stub
      return null;
   }

  @Override
   public List<T> getForList(Connection con, String sql, Object... args) {
      // TODO Auto-generated method stub
      return null;
   }

  @Override
   public T get(Connection con, String sql, Object... args) throws SQLException {
  
      return qr.query(con, sql, new BeanHandler<>(type), args);
   }

  @Override
   public void update(Connection con, String sql, Object... args) {
    // TODO Auto-generated method stub
   }
}

JdbcDAOImpl的子类CustomerDao.java

public class CustomerDao extends JdbcDAOImpl<Customer> {

}

测试类:CustomerDaoTest.java

import static org.junit.Assert.*;
import java.sql.Connection;
import org.junit.Test;
import com.kk.jdbc.JDBCTools;

public class CustomerDaoTest {

  CustomerDao customerDao=new CustomerDao(); 
 
   @Test
   public void testBatch() {
      fail("Not yet implemented");
   }

  @Test
   public void testGetForValue() {
      fail("Not yet implemented");
   }

  @Test
   public void testGetForList() {
      fail("Not yet implemented");
   }

  @Test
   public void testGet() {
  
      Connection con = null;
      try {
   
         con=JDBCTools.getConnection();
         String sql = "select id,name,email from customers where id=?";
         Customer customer=customerDao.get(con, sql, 6);
         System.out.println(customer);
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(null, null, con);
      }
   }

  @Test
   public void testUpdate() {
      fail("Not yet implemented");
   }
}

<十六>JDBC_使用 DBUtils 编写通用的DAO的更多相关文章

  1. MYSQL 之 JDBC(十六): DBUtils

    DBUtils是Apache组织提供的一个开源的JDBC工具类库,能极大简化jdbc编码的工作量 API介绍 QueryRunner ResultSetHandler 工具类DbUtils 用DBUt ...

  2. <十五>JDBC_使用 DBUtils 进行更新、查询操作

    详解待续... DBUtilsTest.java import java.sql.Connection;import java.sql.Date;import java.sql.ResultSet;i ...

  3. 泛型理解及应用(二):使用泛型编写通用型Dao层

    相信目前所有的IT公司网站在设计WEB项目的时候都含有持久层,同样地使用过Hibernate的程序员都应该看过或者了解过Hibernate根据数据库反向生成持久层代码的模板.对于Hibernate生成 ...

  4. <五>JDBC_利用反射及JDBC元数据编写通用的查询方法

    此类针对javaBean类写了一个通用的查询方法,List<javaBean> 通用查询更新中...:通过学习,深刻体会到学会反射就等于掌握了java基础的半壁江山! 一.使用JDBC驱动 ...

  5. Java -- JDBC_利用反射及 JDBC 元数据编写通用的查询方法

    先利用 SQL 进行查询,得到结果集: 利用反射创建实体类的对象:创建对象: 获取结果集的列的别名: 再获取结果集的每一列的值, 结合 3 得到一个 Map,键:列的别名,值:列的值: 再利用反射为 ...

  6. Flask 教程 第十六章:全文搜索

    本文翻译自The Flask Mega-Tutorial Part XVI: Full-Text Search 这是Flask Mega-Tutorial系列的第十六部分,我将在其中为Microblo ...

  7. 编程艺术第十六~第二十章:全排列/跳台阶/奇偶调序,及一致性Hash算法

    目录(?)[+]   第十六~第二十章:全排列,跳台阶,奇偶排序,第一个只出现一次等问题 作者:July.2011.10.16.出处:http://blog.csdn.net/v_JULY_v. 引言 ...

  8. Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制

    在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需 ...

  9. Java学习笔记(十六)——Java RMI

    [前面的话] 最近过的好舒服,每天过的感觉很充实,一些生活和工作的技巧注意了就会发现,其实生活也是可以过的如此的有滋有味,满足现在的状况,并且感觉很幸福. 学习java RMI的原因是最近在使用dub ...

随机推荐

  1. js中JSON格式数据的转化

    JSON.parse(STRING) => OBJECT JSON.stringify(OBJECT) => STRING

  2. 修改linux文件权限

    Linux系统中的每个文件和目录都有访问许可权限,用它来确定谁可以通过何种方式对文件和目录进行访问和操作. 文件或目录的访问权限分为只读,只写和可执行三种.以文件为例,只读权限表示只允许读其内容,而禁 ...

  3. angular1.x的简单介绍 (一)

    angular1.x作为经典的mvc框架,可以创建能够复用的组件,也可进行双向数据绑定.国内的vue.js/avaloon.js都是同类型的框架.适合使用angularjs的项目有大型信息化管理系统: ...

  4. Laravel中的日志与上传

    PHP中的框架众多,我自己就接触了好几个.大学那会啥也不懂啥也不会,拿了一个ThinkPHP学了.也许有好多人吐槽TP,但是个人感觉不能说哪个框架好,哪个框架不好,再不好的框架你能把源码读上一遍,框架 ...

  5. 剑指Offer-【面试题06:重建二叉树】

    package com.cxz.question6; /* * 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字. * 例如:前序遍历序列 ...

  6. NetMQ(一):zeromq简介

    ZeroMQ系列 之NetMQ 一:zeromq简介 二:NetMQ 请求响应模式 Request-Reply 三:NetMQ 发布订阅模式 Publisher-Subscriber 四:NetMQ ...

  7. Drools 函数学习

    Drools 函数学习 函数是定义在规则文件当中一代码块,作用是将在规则文件当中若干个规则都会用到的业务操作封装起来,实现业务代码的复用,减少规则编写的工作量.函数的编写位置可以是规则文件当中 pac ...

  8. 大话css之display的Block未解之谜(一)

    用了几年的css了,css中inline | block |inline-block|table|flex从来没有做过系统的整理和分析,网上的分析文章也很多,零散. 今天有空,就在这做一下整理分析 b ...

  9. 【转】http头部详解

    原地址:http://www.cnblogs.com/ziwuge/archive/2011/09/27/2193385.html HTTP 头部解释 1. Accept:告诉WEB服务器自己接受什么 ...

  10. 修改socket为keepAlive

    参考文章:http://blog.csdn.net/ctthuangcheng/article/details/8596818 [root@mdw- gpadmin]# vi /etc/sysctl. ...