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. PIC32MZ tutorial -- Core Timer

    Core Timer is a very popular feature of PIC32 since it is a piece of the MIPS M4K core itself and is ...

  2. spring-security4.1.2的学习

    spring security教程 spring security是什么? Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架.它提供了 ...

  3. 常见HTTP状态码(200、301、302、500等)

    HTTP状态码,它是用以表示网页服务器HTTP响应状态的3位数字代码.状态码的第一个数字代表了响应的五种状态之一. 1XX系列:指定客户端应相应的某些动作,代表请求已被接受,需要继续处理.由于 HTT ...

  4. Modified Least Square Method and Ransan Method to Fit Circle from Data

    In OpenCv, it only provide the function fitEllipse to fit Ellipse, but doesn't provide function to f ...

  5. Get Intensity along a line based on OpenCV

    The interpolate function is used to get intensity of a point which is not on exactly a pixel. The co ...

  6. Idea安装及简单配置

    1. 安装JDK   设置环境变量   JAVA_HOME    C:\Program Files\Java\jdk1.8.0_45   CLASSPATH    .;%JAVA_HOME%\lib; ...

  7. Haproxy ssl 配置方式

    通过haproxy redirect请求重定向的方法实现HTTP跳转HTTPS 配置实现http跳转到https,采用redirect重定向的做法,只需在frontend端添加: frontend h ...

  8. lnmp

    参照http://www.osyunwei.com/archives/8867.html,略有改动 一 .系统约定 软件源代码包存放位置:/usr/local/src 源码包编译安装位置:/usr/l ...

  9. SQL Server 数据库的维护(二)__触发器

    --维护数据库-- --触发器-- --概述: 触发器是一种特殊类型的存储过程,用来强制执行业务规则.在调用执上,触发器不能像存储过程那样可以由用户通过T-SQL语句直接调用,而是需要有数据库所发生的 ...

  10. MD5在java中的使用

    MD5是什么? MD5是message-digest algorithm 5(信息-摘要算法)的缩写,被广泛用于加密和解密技术上,它可以说是文件的"数字指纹".任何一个文件,无论是 ...