DAO类:

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.kk.jdbc.JDBCTools;
import com.kk.jdbc.ReflectionUtils;

public class DAO {

   //insert、update、delete操作都可以包含其中
   public void update(String sql,Object...args){
      Connection con=null;
      PreparedStatement ps=null;
      try {
   
         con=JDBCTools.getConnection();
         ps=con.prepareStatement(sql);
         for (int i = 0; i < args.length; i++) {
          ps.setObject(i+1, args[i]);
       }
       ps.executeUpdate();
      } catch (Exception e) {
         JDBCTools.release(null,ps, con);
      }
   }
   //查询一条记录,返回对应的对象
   public <T> T get(Class<T> clazz,String sql,Object...args){
  
      List<T> result=getForList(clazz, sql, args);
      if (result.size()>0) {
         return result.get(0);
      }
      return null;
   }
   //查询多条记录,返回对应的对象的集合
   public <T> List<T> getForList(Class<T> clazz,String sql,Object...args){
  
      List<T> list=new ArrayList<>();
      Connection con=null;
      PreparedStatement ps=null;
      ResultSet rs=null;
  
      try {
         /*
          * 1、得到结果集
          *
          * */
         con=JDBCTools.getConnection();
         ps=con.prepareStatement(sql);
         for (int i = 0; i < args.length; i++) {
            ps.setObject(i+1, args[i]);
         }
   
         rs=ps.executeQuery();
         /*
          * 2、处理结果集,得到Map的List,其中一个Map对象就是一条记录;
          *   key-->rs中列的别名
          *   value-->列的值
          * */
         List<Map<String, Object>> values = handleResultSetToMapList(rs);
         /*
          * 3、把Map的List转为clazz对应的集合,其中Map的key即为clazz对应的对象的propertyName
          *    value即为clazz对应对象的propertyValue.
          * */
         list=transfterMapListToBeanList(clazz,  values);
   
      } catch (Exception e) {
         JDBCTools.release(rs, ps, con);
      }
  
      return list;
   }
   private <T> List<T> transfterMapListToBeanList(Class<T> clazz,List<Map<String, Object>> values)
       throws InstantiationException, IllegalAccessException {
  
      List<T> result=new ArrayList<>();
      T bean=null;
      //12、判断list是否为null,不为null遍历,将得到的每一个Map对象转为一个Class参数对应的Object对象
      if (values.size()>0) {
         for (Map<String, Object> m : values) {
            bean=clazz.newInstance();
            for (Map.Entry<String,Object> entry: m.entrySet()) {
               String propertyName=entry.getKey();
               Object value=entry.getValue();
               ReflectionUtils.setFieldValue(bean, propertyName, value);
            }
            //13、把Object对象放入到list中
            result.add(bean);
         }
      }
      return result;
   }
 
   //处理结果集,得到Map的一个List,其中一个Map对应一条记录
   private List<Map<String, Object>> handleResultSetToMapList(ResultSet rs) throws SQLException {
      //5、准备一个List<Map<String,Object>>,一个Map对象对应一条记录
      List<Map<String,Object>> values=new ArrayList<>();
      List<String> columnLabels=getColumnLabels(rs);
      Map<String,Object> map=null;
      //7、处理ResultSet,使用while循环
      while(rs.next()){
         map=new HashMap<>();
   
         for (String columnLabel:columnLabels) {
            Object value=rs.getObject(columnLabel);
            map.put(columnLabel, value);
         }
         //11、将填充好的Map对象放入list中
         values.add(map);
      }
      return values;
   }
 
   //获取结果集的ColumnLabel对应的List
   private List<String> getColumnLabels(ResultSet rs) throws SQLException{
  
      List<String> labels=new ArrayList<>();
  
      ResultSetMetaData rsmd=rs.getMetaData();
      for (int i = 0; i < rsmd.getColumnCount(); i++) {
         labels.add(rsmd.getColumnLabel(i+1));
      }
  
      return labels;
   }
 
   //返回某个对象的属性值
   public <E>  E getForValue(String sql,Object...args){
  
      //1、得到结果集:该结果集应该只有一行且只有一列
      Connection con=null;
      PreparedStatement ps=null;
      ResultSet rs=null;
      try {
   
         con=JDBCTools.getConnection();
         ps=con.prepareStatement(sql);
         for (int i = 0; i < args.length; i++) {
            ps.setObject(i+1, args[i]);
         }
         rs=ps.executeQuery();
   
         if (rs.next()) {
              return (E) rs.getObject(1);
         }
   
      } catch (Exception e) {
         e.printStackTrace();
      }finally{
         JDBCTools.release(rs, ps, con);
      }
  
      //2、取得结果集的
  
  
        return null;
     }
  }

单元测试类:

import java.sql.Date;
import java.util.List;
import org.junit.Test;
import com.kk.jdbc.Student;

  public class DAOTest {

    DAO dao=new DAO();
 
     @Test
     public void testUpdate() {
      String sql="insert into customers(name,email,birth) values (?,?,?)";
      dao.update(sql, "xiaoming","xm@.com",new Date(new java.util.Date().getTime()));
  
   }

  @Test
   public void testGet() {
      String sql="select FlowId flow_Id,Type,IDCard,ExamCard,StudentName from examstudent where FlowId=?";
      Student stu=dao.get(Student.class,sql,1);
      System.out.println(stu);
   }

  @Test
    public void testGetForList() {
      String sql="select FlowId flow_Id,Type,IDCard,ExamCard,StudentName from examstudent";
      List<Student> st=dao.getForList(Student.class, sql);
      System.out.println("向日葵:"+st);
    }

  @Test
   public void testGetForValue() {
      String sql="select ExamCard from examstudent where FlowId=?";
      String examCard=dao.getForValue(sql, 13);
      System.out.println(examCard);
  
      sql="select max(grade) from examstudent";
      int grade=dao.getForValue(sql);
      System.out.println(grade);
   }

}

<八>JDBC_重构DAO查询方法的更多相关文章

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

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

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

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

  3. MyBatis学习--mybatis开发dao的方法

    简介 使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法. 主要概念介绍: MyBatis中进行Dao开发时候有几个重要的类,它们是SqlSessionFac ...

  4. 11Mybatis_mybatis开发Dao的方法

    在介绍开发Dao的方法之前先介绍下SqlSession. 1.先介绍一下SqlSessionFactoryBuilder:通过SqlSessionFactoryBuilder创建会话工厂SqlSess ...

  5. 四 mybatis开发dao的方法

    mybatis开发dao的方法 1.1     SqlSession使用范围 1.1.1     SqlSessionFactoryBuilder //以流的方式读取总的配置文件 Reader rea ...

  6. mybatis系列-04-mybatis开发dao的方法

    4.1     SqlSession使用范围 4.1.1     SqlSessionFactoryBuilder 通过SqlSessionFactoryBuilder创建会话工厂SqlSession ...

  7. Hibernate查询方法总结

    1. HQL查询 HQL是Hiberante官方推荐的Hibernate检索方式,它使用类似SQL的查询语言,以面向对象的方式从数据库中查询.可以使用HQL查询具有继承.多态和关 联关系的数据.在检索 ...

  8. Mybatis的原始dao开发方法

    在进入主题之前先提一下sqlSession.sqlSession是一个面向用户(程序员)的接口. sqlSession中提供了很多操作数据库的方法,如: selectOne(返回单个对象).selec ...

  9. J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())

    J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())   当我们使用Hibernate进行数据的CRUD操作时,利用模版进行操作不失为一种方法. ...

随机推荐

  1. PHP的继承方法如何获取子类名?get_class() 和 get_called_class()

    PHP里的__CLASS__这类东西是静态绑定的,如果不在子类里重载的话,那么继承父类方法所得到的依旧是父类的名称,而不是子类的名称,比如: <?php class A { function _ ...

  2. BZOJ2435——[Noi2011]道路修建

    1.题意:给个树,边的权值=两边的点数差*此边的长度,求所有边的权值和 2.分析:真不想说啥了...dfs即可 #include <cmath> #include <cstdio&g ...

  3. PYTHON 写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容。

    def shifou_space(args): ret = True for a in args: if a.isspace(): ret = False break return ret resul ...

  4. getComputedStyle的简单用法

    var number=window.getComputedStyle("元素").style样式名

  5. Java MySql 批量插入数据库addBatch

    //addBatch批量插入数据库 public static void insertCommentToMySql(Set<String> commentList) { Iterator& ...

  6. asp:DataGrid之添加asp:CheckBox做全选功能时涉及到绑值问题解决

    最大的意图是为asp:CheckBox的value绑定上自己需要的value值,而不是默认的字符串"on" 参考了这篇文章带Value属性的扩展CheckBox控件,意义不大,换了 ...

  7. 【转】python编码的问题

    摘要: 为了在源代码中支持非ASCII字符,必须在源文件的第一行或者第二行显示地指定编码格式: # coding=utf-8 或者是: #!/usr/bin/python # -*- coding: ...

  8. VS2013无法连接到SqlServer的问题解决

    在本机安装Vs2013后,安装Sqlserver2012数据库,在VS开发时,数据库一直查询不到 点击刷新后,看不见本机Sql服务器 最初检查防火墙设置,发现添加sqlservr.exe依然不起作用 ...

  9. javaWeb项目部署到阿里云服务器步骤

    记录web项目部署到阿里云服务器步骤 (使用 web项目.阿里云服务器.Xftp.Xshell),敬请参考和指正 1.将要部署的项目打包成WAR文件格式,可以在MyEclipse.Eclipse都可以 ...

  10. yii 常用的多表查询

    return $this->model()->getDbConnection()->createCommand() ->select("t.type,t.title, ...