1. DAO全称:Data Access Object , 数据访问对象。使用DAO设计模式来封装数据持久化层的所有操作(CRUD),使得数据访问逻辑和业务逻辑分离,实现解耦的目的。

2. 典型的DAO实现组件:DAO接口 + DAO接口的实现类

3. 事例代码

  1)javabean组件:用于数据传输的对象

/** javabean数据传输对象 */
public class Customer {
    // 和数据库中的表是对应的
    private int id;
    private String name;
    private String email;

    // 省略getter()/setter()方法

    @Override
    public String toString() {
        return id + ", " + name + ", " + email;
    }
}

  2)DAO接口

/** DAO接口,用于定义application访问数据库的通用方法  */
public interface CustomerDemo {
    // CRUD
    public void add(Customer c);
    public void update(Customer    c);
    public void delete(int id);
    public Customer getCustomerById(int id);
    public List<Customer> queryList();

}

  3)DAO接口的实现类

 package com.znker.jdbc;

 import java.sql.Connection;
 import java.sql.PreparedStatement;
 import java.sql.ResultSet;
 import java.sql.SQLException;
 import java.sql.Statement;
 import java.util.ArrayList;
 import java.util.List;

 // DAO接口的实现类

 public class CustomerDaoImpl implements CustomerDemo {

     @Override
     public void add(Customer c) {
         String sql = "insert into CustomerTb1(name,email) values(?,?)";
         // 获得一个数据库连接对象
         Connection conn = DBUtil2.open();

         try {
             // 预定义语句对象
             PreparedStatement pstmt = conn.prepareStatement(sql);
             // 对占位符进行赋值
             pstmt.setString(1, c.getName());
             pstmt.setString(2, c.getEmail());
             // 执行添加操作
             pstmt.executeUpdate();

         } catch (SQLException e) {
             e.printStackTrace();
         } finally {
             DBUtil2.close(conn);
         }
     }

     @Override
     public void update(Customer c) {
         String sql = "update CustomerTb1 set name=?, email=? where id=?";
         Connection conn = DBUtil2.open();

         try {
             PreparedStatement pstmt = conn.prepareStatement(sql);
             pstmt.setInt(3, c.getId());
             pstmt.setString(1, c.getName());
             pstmt.setString(2, c.getEmail());

             pstmt.executeUpdate();

         } catch (SQLException e) {
             e.printStackTrace();
         } finally {
             DBUtil2.close(conn);
         }
     }

     @Override
     public void delete(int id) {
         String sql = "delete from CustomerTb1 where id = ?";
         Connection conn = DBUtil2.open();

         try {
             PreparedStatement pstmt = conn.prepareStatement(sql);
             pstmt.setInt(1, id);

             pstmt.executeUpdate();

         } catch (SQLException e) {
             e.printStackTrace();
         } finally {
             DBUtil2.close(conn);
         }
     }

     @Override
     public Customer getCustomerById(int id) {
         String sql = "select id, name, email from CustomerTb1 where id = ?";
         Connection conn = DBUtil2.open();

         try {
             PreparedStatement pstmt = conn.prepareStatement(sql);
             pstmt.setInt(1, id);

             ResultSet rs = pstmt.executeQuery();

             if (rs.next()) {
                 String name = rs.getString(2);
                 String email = rs.getString("email");

                 Customer c = new Customer();
                 c.setId(id);
                 c.setName(name);
                 c.setEmail(email);

                 return c;
             }
         } catch (SQLException e) {
             e.printStackTrace();
         }

         return null;
     }

     @Override
     public List<Customer> queryList() {
         String sql = "select id, name, email from CustomerTb1 ";
         Connection conn = DBUtil2.open();

         try {
             Statement stmt = conn.createStatement();
             ResultSet rs = stmt.executeQuery(sql);
             List<Customer> list = new ArrayList<Customer>();

             while (rs.next()) {
                 int id = rs.getInt(1);
                 String name = rs.getString(2);
                 String email = rs.getString("email");

                 Customer c = new Customer();
                 c.setId(id);
                 c.setName(name);
                 c.setEmail(email);

                 list.add(c);
             }

             return list;
         } catch (SQLException e) {
             e.printStackTrace();
         } finally {
             DBUtil2.close(conn);
         }

         return null;
     }

 }

  4)测试代码

import java.util.ArrayList;
import java.util.List;

public class DaoTest {

    public static void main(String[] args) {

        // DAO接口的实现对象,用户业务层访问数据库
        CustomerDemo dao = new CustomerDaoImpl();

        // 添加一个用户
        Customer c = new Customer();
        c.setName("bobo");
        c.setEmail("bobo@qq.com");
        dao.add(c);

        // 查询一个用户List
        List<Customer> list = new ArrayList<Customer>();
        list = dao.queryList();
        System.out.println(list);

    }
}

JavaWeb技术(二):DAO设计模式的更多相关文章

  1. JavaWeb学习笔记——DAO设计模式

  2. 一、DAO设计模式 二、DAO设计模式的优化 三、JDBC中的事务,连接池的使用

    一.DAO设计模式概述###<1>概念 DAO,Data Access Object ,用于访问数据库的对象. 位于业务逻辑和数据持久化层之间,实现对数据持久化层的访问![](1.png) ...

  3. java之 ------ DAO设计模式的【具体解释】及常见设计模式的【应用】

    DAO Data Access Object(数据訪问接口) 一.场景和问题 在Java程序中.常常须要把数据持久化,也须要获取持久化的数据.可是在进行数据持久化的过程中面临诸多问题(如:数据源 不同 ...

  4. 走进JavaWeb技术世界1:JavaWeb的由来和基础知识

    本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...

  5. 对于使用javaweb技术制作简单管理系统的学习

    近期在老师的引导下我们学习了利用Javaweb技术制作简单的管理系统,其中涉及到的技术很多,由于大多都是自学 对这些技术的理解还太浅显但能实现一些相关功能的雏形. (一).登录功能 在登陆功能中通过与 ...

  6. Java Dao设计模式

    一.信息系统的开发架构   客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/S ...

  7. MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  8. DAO设计模式 -- 使用数据库连接类连接MySql数据库并实现添加用户

    1. DAO简介    DAO设计模式是属于J2EE数据库层的操作,使用DAO设计模式可以简化大量代码,增强程序的可移植性. 2. DAO各部分详解    DAO设计模式包括5个重要的部分,分别为数据 ...

  9. JavaBean中DAO设计模式介绍(转)

    一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/Ser ...

随机推荐

  1. 装tomcat和nginx心得

    开机启动tomcat 1:在/etc/rc.d/init.d目录下生成一个文件tomcat8080 2:在文件里添加如下内 #!/bin/bash #2345 linux运行级别 #10开机启动优先级 ...

  2. 内容生成器:content、计数器、多列

    一,内容生成器:content 补充before和after伪类选择器: 1):将内容添加到某个选择器定义的单个或者多个元素的每一个实例之前或者之后 2)与before选择器配合使用(同理大家想下会不 ...

  3. thinkphp修改及编写标签库,编辑器的使用

    在view目录下创建Index_aaa.html <!DOCTYPE html> <html> <head> <meta charset="UTF- ...

  4. java自编时间工具类

    package timeTools; import java.text.ParseException; import java.text.SimpleDateFormat; import java.u ...

  5. select 一直返回0

    select设置超时时间后一直返回零,是因为每次select后监听的fd_set都被重置,解决方法就是每次重新设置

  6. HostOnly Cookie和HttpOnly Cookie

    怎么使用Cookie? 通常我们有两种方式给浏览器设置或获取Cookie,分别是HTTP Response Headers中的Set-Cookie Header和HTTP Request Header ...

  7. HDOJ(1115)多边形重心

    Lifting the Stone http://acm.hdu.edu.cn/showproblem.php?pid=1115 题目描述:输入n个顶点(整数),求它们围成的多边形的重心. 算法:以一 ...

  8. 很不错的sql练习题(select)

      创建表和输入数据 CREATE TABLE STUDENT (SNO VARCHAR(3) NOT NULL,    SNAME VARCHAR(4) NOT NULL,    SSEX VARC ...

  9. angularJs基础

    AngularJs是为了克服Html在构建应用上的不足而设计的.Html是一门很好的为静态文件展示设计的声明式语言,但是要构建web应用的话就显得乏力了.所以我做了一些工作来让浏览器做我瞎向要的事. ...

  10. c语言,检测一个无符号整数中是否有偶数位个1

    最近在学习大牛Bryant O'Hallaron 的深入理解计算机系统,发现学了这么久的程序设计,其实有些基本的东西还不太了解,这不,这两天在恶补整数,浮点数在计算机中的表示,并且开始做上面的习题, ...