JavaWeb技术(二):DAO设计模式
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设计模式的更多相关文章
- JavaWeb学习笔记——DAO设计模式
- 一、DAO设计模式 二、DAO设计模式的优化 三、JDBC中的事务,连接池的使用
一.DAO设计模式概述###<1>概念 DAO,Data Access Object ,用于访问数据库的对象. 位于业务逻辑和数据持久化层之间,实现对数据持久化层的访问 ...
- java之 ------ DAO设计模式的【具体解释】及常见设计模式的【应用】
DAO Data Access Object(数据訪问接口) 一.场景和问题 在Java程序中.常常须要把数据持久化,也须要获取持久化的数据.可是在进行数据持久化的过程中面临诸多问题(如:数据源 不同 ...
- 走进JavaWeb技术世界1:JavaWeb的由来和基础知识
本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...
- 对于使用javaweb技术制作简单管理系统的学习
近期在老师的引导下我们学习了利用Javaweb技术制作简单的管理系统,其中涉及到的技术很多,由于大多都是自学 对这些技术的理解还太浅显但能实现一些相关功能的雏形. (一).登录功能 在登陆功能中通过与 ...
- Java Dao设计模式
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/S ...
- MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- DAO设计模式 -- 使用数据库连接类连接MySql数据库并实现添加用户
1. DAO简介 DAO设计模式是属于J2EE数据库层的操作,使用DAO设计模式可以简化大量代码,增强程序的可移植性. 2. DAO各部分详解 DAO设计模式包括5个重要的部分,分别为数据 ...
- JavaBean中DAO设计模式介绍(转)
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/Ser ...
随机推荐
- 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 ...
- spring-security4.1.2的学习
spring security教程 spring security是什么? Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架.它提供了 ...
- 常见HTTP状态码(200、301、302、500等)
HTTP状态码,它是用以表示网页服务器HTTP响应状态的3位数字代码.状态码的第一个数字代表了响应的五种状态之一. 1XX系列:指定客户端应相应的某些动作,代表请求已被接受,需要继续处理.由于 HTT ...
- 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 ...
- 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 ...
- Idea安装及简单配置
1. 安装JDK 设置环境变量 JAVA_HOME C:\Program Files\Java\jdk1.8.0_45 CLASSPATH .;%JAVA_HOME%\lib; ...
- Haproxy ssl 配置方式
通过haproxy redirect请求重定向的方法实现HTTP跳转HTTPS 配置实现http跳转到https,采用redirect重定向的做法,只需在frontend端添加: frontend h ...
- lnmp
参照http://www.osyunwei.com/archives/8867.html,略有改动 一 .系统约定 软件源代码包存放位置:/usr/local/src 源码包编译安装位置:/usr/l ...
- SQL Server 数据库的维护(二)__触发器
--维护数据库-- --触发器-- --概述: 触发器是一种特殊类型的存储过程,用来强制执行业务规则.在调用执上,触发器不能像存储过程那样可以由用户通过T-SQL语句直接调用,而是需要有数据库所发生的 ...
- MD5在java中的使用
MD5是什么? MD5是message-digest algorithm 5(信息-摘要算法)的缩写,被广泛用于加密和解密技术上,它可以说是文件的"数字指纹".任何一个文件,无论是 ...