Dao设计模式简单实现
一、什么是Dao设计模式
Dao设计模式封装了操作具体数据库的细节,对业务层提供操作数据库的接口,因此降低了业务层代码与具体数据库之间的耦合,有利于人员分工,增加了程序的可移植性。
Dao设计模式中主要包含这5个模块:
1、VO类:VO(Value Object)即值对象,每一个值对象对应一张数据库表,便于我们传递数据。
2、Dao接口:Dao接口定义了操作数据库的方法,业务层通过调用这些方法来操作数据库。
3、Dao实现类:操作数据库的方法的具体实现,封装了操作数据库的细节。
4、Dao工厂类:用于代替new操作,进一步降低业务层与数据层之间的耦合。
5、数据库连接类:封装了连接数据库、关闭数据库等常用的操作,减少重复编码。
下面我们应用Dao设计模式来实现一个简单的转账操作,加深对其的理解。
二、Dao设计模式实现
首先,我们创建vo、dao、factory、util包来分别存放Dao设计模式5个模块的代码。因为我们使用的是JDBC连接MySQL数据库,所以还需要创建一个lib包存放并引用JDBC驱动。除此之外,我们还需要创建一个test包进行代码的测试。创建好后的目录结构如下:

接着设计一张user表,表中包含了用户基本信息和余额,并插入一些数据。

根据user表在vo包中创建VO类user.java。
package vo;
public class User {
private int id;
private String username;
private int sum;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public int getSum() {
return sum;
}
public void setSum(int sum) {
this.sum = sum;
}
@Override
public String toString() {
return "User [id=" + id + ", username=" + username + ", sum=" + sum + "]";
}
}
在util包中创建数据库连接类JDBC.java。
package util; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; public class JDBC {
//获取数据库链接
public static Connection getConnection() {
Connection con = null;
try {
String url = "jdbc:mysql://localhost:3306/user?serverTimezone=Asia/Shanghai";
Class.forName("com.mysql.cj.jdbc.Driver");
con = DriverManager.getConnection(url, "root", "root");
} catch (Exception e) {
e.printStackTrace();
}
return con;
}
//关闭资源
public static void close(Connection con, Statement st, ResultSet rs) {
try {
if (rs != null) {
rs.close();
}
if (st != null) {
st.close();
}
if (con != null) {
con.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
}
经过分析,该转账系统需要两类数据库操作,分别是“查询用户信息”和“更新用户余额”。因此我们在dao包中创建IUserDao.java接口并定义这两种方法。
package dao; import java.sql.Connection;
import java.sql.SQLException; import vo.User; public interface IUserDao {
//根据用户名查找用户信息
public User selectUserByName(Connection con, User user);
//根据用户名更新用户余额
public int updateSumByName(Connection con, User user) throws SQLException;
}
接着在dao包中创建该接口的实现类UserDaoImpl.java,实现这两种方法。
package dao; import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import util.JDBC;
import vo.User; public class UserDaoImpl implements IUserDao { @Override
public User selectUserByName(Connection con, User user) {
String sql = "select * from user where username = ?";
PreparedStatement pStatement = null;
ResultSet rs = null;
try {
pStatement = con.prepareStatement(sql);
pStatement.setString(1, user.getUsername());
rs = pStatement.executeQuery();
if (rs.next()) {
user.setId(rs.getInt("id"));
user.setUsername(rs.getString("username"));
user.setSum(rs.getInt("sum"));
return user;
}
} catch (SQLException e) {
e.printStackTrace();
}finally {
JDBC.close(null, pStatement, rs);
}
return null;
} @Override
public int updateSumByName(Connection con, User user) throws SQLException {
String sql = "update user set sum = ? where username = ?";
PreparedStatement pStatement = null;
try {
pStatement = con.prepareStatement(sql);
pStatement.setInt(1, user.getSum());
pStatement.setString(2, user.getUsername());
return pStatement.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
//抛出异常,便于进行事务处理
throw e;
}finally {
JDBC.close(null, pStatement, null);
}
}
}
最后,我们还需要在factory包中创建Dao工厂类DaoFactory.java。
package factory; import dao.IUserDao;
import dao.UserDaoImpl; public class DaoFactory {
public static IUserDao getUserDao() {
return new UserDaoImpl();
}
}
到这里,转账系统的Dao层就设计好了。我们在test包中创建Main.java进行测试。
package test; import java.sql.Connection;
import java.sql.SQLException; import dao.IUserDao;
import factory.DaoFactory;
import util.JDBC;
import vo.User; public class Main { public static void main(String[] args) {
Connection con = JDBC.getConnection();
IUserDao userDao = DaoFactory.getUserDao();
//被转账的用户
User user_in = new User();
user_in.setUsername("ysy");
user_in = userDao.selectUserByName(con, user_in);
System.out.println(user_in);
//转账的用户
User user_out = new User();
user_out.setUsername("管理员");
user_out = userDao.selectUserByName(con, user_out);
System.out.println(user_out);
//转账30元
user_in.setSum(user_in.getSum() + 30);
user_out.setSum(user_out.getSum() - 30);
//事务处理
try {
con.setAutoCommit(false);
userDao.updateSumByName(con, user_in);
userDao.updateSumByName(con, user_out);
con.commit();
} catch (Exception e) {
e.printStackTrace();
try {
con.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
}
//查询转账结果
user_in = userDao.selectUserByName(con, user_in);
System.out.println(user_in);
user_out = userDao.selectUserByName(con, user_out);
System.out.println(user_out);
JDBC.close(con, null, null);
}
}
执行结果如下:

最终的目录结构如下:

Dao设计模式简单实现的更多相关文章
- 简单的Dao设计模式
简单的DAO设计模式 这两天学习到了DAO(Data Access Object 数据存取对象)设计模式.想谈谈自己的感受,刚开始接触是感觉有点难,觉得自己逻辑理不清,主要是以前学的知识比较零散没有很 ...
- Java Dao设计模式
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/S ...
- JavaBean中DAO设计模式介绍(转)
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/Ser ...
- JavaBean在DAO设计模式简介
一.信息系统开发框架 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层是client,简单的来说就是浏览器. 2.显示层:JSP/Se ...
- JavaBean中DAO设计模式介绍
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是client,简单的来说就是浏览器. 2.显示层:JSP/ ...
- DAO设计模式(转)
J2EE开发人员使用数据访问对象(DAO)设计模式把底层的数据访问逻辑和高层的商务逻辑分开.实现DAO模式能够更加专注于编写数据访问代码. 我们先来回顾一下DAO设计模式和数据访问对象. DAO基础 ...
- JavaBean中DAO设计模式简介
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/Ser ...
- DAO设计模式
DAO设计模式 DAO设计模式简介: DAO设计模式可以减少代码量,增强程序的可移植性,提高代码的可读性. DAO(数据库操作对象)设计模式是 JavaEE 数据层的操作.主要由五部分组成: 1.数据 ...
- JavaWeb技术(二):DAO设计模式
1. DAO全称:Data Access Object , 数据访问对象.使用DAO设计模式来封装数据持久化层的所有操作(CRUD),使得数据访问逻辑和业务逻辑分离,实现解耦的目的. 2. 典型的DA ...
随机推荐
- qt 布局管理按钮控件间有空隙?
定义了几个按钮控件,想要按钮间没有空隙,我使用setspaces(0)来设置它们之间的间隔. 结果控件间还是有空隙,如图 我对控件所在的widget的背景进行设置,(会把style传到子控件)发现结果 ...
- 【概率论】2-1:条件概率(Conditional Probability)
title: [概率论]2-1:条件概率(Conditional Probability) categories: Mathematic Probability keywords: Condition ...
- CSPS模拟75&76
感觉自己还是太菜了... 最近考试一直想不出来正解.难受(然而蒟蒻的博客没人看也要不来小猪peiqi的图) 模拟75:血炸... 考场上推了快两个小时的T1式子,然后心态炸裂,然后我也不知道自己干了什 ...
- Python互联网金融之用户增长的数据逻辑
怎样看待和应用我们互联网金融中的数据? 怎样进行数据分析? 互联网金融数据分析的三个层面: (1)指标层面 建立指标体系,观察指标涨跌的情况 (2)行业框架 不同的行业对于各个指标的权重不同 复投率 ...
- Reids入门介绍
一.入门概述 1.是什么? Redis:REmote DIctionary Server(远程字典服务器) 是完全开源免费的,用C语言编写的,遵守BSD协议,是一个高性能的(key/value)分布式 ...
- ArcGIS超级工具SPTOOLS-SHP转数据库,批量数据库转数据库,栅格彩色转黑白
1.1 SHP转数据库 把一个文件夹的数据,转到数据库,或者另一个文件夹,不含字文件夹 1.2 批量数据库转数据库 把一个文件夹下GDB或者MDB,转到另一个文件夹为MDB,GDB,并实现版本的转 ...
- Flume-自定义 Source 读取 MySQL 数据
开源实现:https://github.com/keedio/flume-ng-sql-source 这里记录的是自己手动实现. 测试中要读取的表 CREATE TABLE `student` ( ` ...
- 《maven实战》笔记(1)----maven的初识
刚入职公司用maven进行项目管理,于是昨天下午开始看<maven实战>的pdf,感觉很好,作者写的很有条理. 下面是笔记,看书做笔记还是很有必要的,加强自己的总结. 什么是maven? ...
- MyISAM与InnoDB之间的区别
区别: 1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事 ...
- IEnumerable和IQueryable口的区别
IQueryable: 动态表达式树拼接查询语句,把拼接后查询语句进行执行:Execute触发,延迟加载IEnumerable:对内存中的数据,动态拼接查询语句,进行查询:ToList触发,延迟加载: ...