JDBC_DAO设计模式
 DAO:Data Access Object(数据访问对象)
  why:实现功能的模块化,更有利于代码的维护和升级。
  what:访问数据信息的类,包含了对数据的CRUD(create、read、update、delete),而不包含任何业务相关
  的信息。
  
  该DAO可以被子类继承或直接使用。
  
  how:使用JDBC编写DAO可能会包含的方法:
   //insert、update、delete操作都可以包含其中
   void update(String sql,Object...args);
   //查询一条记录,返回对应的对象
   <T> T get(Class<T> clazz,String sql,Object...args);
   //查询多条记录,返回对应的对象的集合
   <T> List<T> getForList(Class<T> clazz,String sql,Object...args);
   //返回某个对象的属性值
   <E>  E getForValue(String sql,Object...args);

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
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) {
   
  }
 }
 //查询一条记录,返回对应的对象
 public <T> T get(Class<T> clazz,String sql,Object...args){
  
  /*
   * 1、获取Connection
   * 2、获取PreparedStatement
   * 3、填充占位符
   * 4、进行查询,得到ResultSet
   * 5、准备一个Map<String,Object>对象,键->存放列的别名,键->存放列的值
   * 6、得到ResultSetMetaData对象
   * 7、处理ResultSet,把指针向下移动一个单位
   * 8、由ResultSetMetaData得到结果集中有多少列
   * 9、由ResultSetMetaData得到每一列的别名,由ResultSet得到具体每一列的值
   * 10、填充Map对象
   * 11、用反射创建Class对应的对象
   * 12、遍历Map对象,用反射填充对象的属性值:
   *   属性名为Map中的key,属性值为Map中的value
   * */
  
  T entity=null;
  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()) {
    Map<String,Object> values=new HashMap<>();
    ResultSetMetaData rsmd=rs.getMetaData();
    int columnCount=rsmd.getColumnCount();
    for (int i = 0; i < columnCount; i++) {
     String columnLabel=rsmd.getColumnLabel(i+1);
     Object columnValue=rs.getObject(columnLabel);
     values.put(columnLabel, columnValue);
    }
    
    entity=clazz.newInstance();
    
    for (Map.Entry<String, Object> entry : values.entrySet()) {
     String propertyName=entry.getKey();
     Object value=entry.getValue();
     //用反射赋值
     ReflectionUtils.setFieldValue(entity, propertyName, value);     
    }
    
   }
   
  } catch (Exception e) {
   e.printStackTrace();
  }
  return entity;
 }
 //查询多条记录,返回对应的对象的集合
 public <T> List<T> getForList(Class<T> clazz,String sql,Object...args){
  
  return null;
 }
 //返回某个对象的属性值
 public <E>  E getForValue(String sql,Object...args){
  
  return null;
 }
}

import static org.junit.Assert.*;
import java.sql.Date;
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() {
  fail("Not yet implemented");
 }

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

}

<六>JDBC_DAO 设计模式的更多相关文章

  1. JavaScript高级程序设计学习(六)之设计模式

    每种编程语言都有其自己的设计模式.不禁让人疑惑设计模式是用来做什么?有什么用? 简单的说,设计模式是为了让代码更简洁,更优雅,更完美. 同时设计模式也会让软件的性能更好,同时也会让程序员们更轻松.设计 ...

  2. 大型Java进阶专题(六)设计模式之代理模式

    代理模式 前言 又开始我的专题了,又停滞了一段时间了,加油继续吧.都知道 SpringAOP 是用代理模式实现,到底是怎么实现的?我们来一探究竟,并且自己仿真手写还原部分细节. 代理模式的应用 在生活 ...

  3. Java -- JDBC_DAO 设计模式

    DAO:Date Access Object 实现代码模块化,更加有利于代码的维护和升级. DAO 可以被子类继承或者直接使用. 访问数据信息的类,包含对数据的CRUD(create read upd ...

  4. python_way,day8 面向对象【多态、成员--字段 方法 属性、成员修饰符、特殊成员、异常处理、设计模式之单例模式、模块:isinstance、issubclass】

    python_way day8 一.面向对象三大特性: 多态 二.面向对象中的成员 字段.方法属性 三.成员修饰符 四.特殊成员 __init__.__doc__.__call__.__setitem ...

  5. Java常见设计模式学习(非原创)

    文章大纲 一.策略模式二.观察者模式三.工厂模式四.单例模式五.其他模式六.设计模式总结七.参考文章   一.策略模式 现在假设我们有个"鸭子项目",首先我们用OOP(面向对象)的 ...

  6. JAVA总结--设计模式

    三大类设计模式: 创建型模式,共五种:工厂方法模式.抽象工厂模式.单例模式.建造者模式.原型模式. 结构型模式,共七种:适配器模式.装饰器模式.代理模式.外观模式.桥接模式.组合模式.享元模式. 行为 ...

  7. Java书籍推荐

    Java书籍推荐 转自:http://www.cnblogs.com/exclm/archive/2009/01/03/1367597.html 一.入门 <Java 2从入门到精通>- ...

  8. python学习之路基础篇(第八篇)

    一.作业(对象的封装) 要点分析 1.封装,对象中嵌套对象 2.pickle,load,切记,一定要先导入相关的类二.上节内容回顾和补充 面向对象基本知识: 1.类和对象的关系 2.三大特性: 封装 ...

  9. java面试总结

    一.java的集合框架 HashMap.HashTable.CurrentHashMap的底层数据结构与区别? CurrentHashMap与HashTable是如何保证线程安全的? ArrayLis ...

随机推荐

  1. vue2.0学习(一)

    1.解决双花括号在初始化时的闪烁,两种方式,一种是<div v-text="name"></div>,将用v-text指令来显示,类似于angular的ng ...

  2. redis集群之REDIS CLUSTER

    redis集群之REDIS CLUSTER 时间 2016-04-11 17:05:00  NoSQL_博客园 原文  http://www.cnblogs.com/zhanchenjin/p/537 ...

  3. CSS自适应布局(左右固定 中间自适应或者右侧固定 左侧自适应)

    经常在工作中或者在面试中会碰到这样的问题,比如我想要个布局 右侧固定宽度 左侧自适应 或者 三列布局 左右固定 中间自适应的问题. 下面我们分别来学习下,当然我也是总结下而已,有如以下方法: 一: 右 ...

  4. Oracle 过程中检查数据表存在与否

    在过程中,尤其是每天执行的任务,通常要检查查询的数据表存在不存在,如果不存在则等待一段时间在进行执行,以下代码实现了这个功能,如果表不存在,抛出异常,交给异常处理代码,确保数据完整性 使用方法:p_C ...

  5. Java JVM类加载机制

    虚拟机的类加载机制是:JVM把描述类的数据从.class文件加载到内存,并对数据进行校验.解析.初始化,最终形成可以被JVM直接使用的Java类型. 加载.连接(验证.准备.解析).初始化.使用.卸载 ...

  6. go:interface{}、断言与类型转换

    interface{}可用于向函数传递任意类型的变量,但对于函数内部,该变量仍然为interface{}类型(空接口类型), 不清楚这点将可能导致错误.如以下代码: package main impo ...

  7. C#中将DataTable转成List

    学习MVC的时候,使用List<T>来存储数据给前台,但是从数据库中直接读取得到的是DataTable,虽然可以直接循环DataTable来得到list,但是如果每个实体类都通过这样的得到 ...

  8. 【学习笔记】ES6标准入门

    这里简要记录一下对自己感触比较深的几个知识点,将核心的应用投放于实际的项目之中,提供代码的可维护性. 一.let和const { // let声明的变量只在let命令所在的代码块内有效 let a = ...

  9. vim使用技巧

    1.vim 编辑下内容复制.剪切到windows下 "+y 或 "+d 2.从win 复制到 vim CTRL+Shift+v 3.选择文字 v+方向键

  10. hdu 1358 Period

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1358 思路:Next数组的用法,在第i个位置上如果有i%(i-Next[i])==0的话最小循环节就是 ...