DAO设计模式

  DAO设计模式简介: DAO设计模式可以减少代码量,增强程序的可移植性,提高代码的可读性。

  DAO(数据库操作对象)设计模式是 JavaEE 数据层的操作.主要由五部分组成:

    1.数据库连接类:连接数据库并获取连接对象。

    2.VO实体类:包含属性和表中字段完全对应的类。

    3.DAO接口:提供了用户所有的操作方法(就如老师给学生提供一些学习方法)。

    4.DAO实现类:实现DAO中所有的方法(就如老师给提供的方法看你如何去完成)。

    5.DAO工厂类:为程序提供方法,如果要替换DAO实现类,只需要修改该Dao工厂类中的方法代码,

而不必邀修改所有的操作数据库代码(如代理人专门为需要的公司提供人才,也叫做服务层)。

下面以一个用户登录为例:

  1.数据库建表:

  2.数据库连接类  com.util(记得导入c3p0框架包)

package com.util;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.sql.DataSource;
import com.mchange.v2.c3p0.ComboPooledDataSource; public class C3P0Util {
// C3P0数据源
private static ComboPooledDataSource dataSource = new ComboPooledDataSource(); public static DataSource getDataSource() {
return dataSource;
} public static Connection getConn() {
Connection conne = null;
try {
conne = dataSource.getConnection();
} catch (Exception e) {
e.printStackTrace();
}
return conne;
} // 关闭资源
public static void closeAll(ResultSet rs, Statement st, Connection conne) {
try {
if (null != rs) {
rs.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if (null != st) {
st.close();
}
} catch (Exception e) {
e.printStackTrace();
}
try {
if (conne != null) {
conne.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}

  3.VO实体类  com.entity

package com.entity;

import java.io.Serializable;

public class Person implements Serializable {

    private static final long serialVersionUID = 1L;

    private int id;
private String name;
private String password; public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} }

  

  4.DAO接口类  com.dao

package com.dao;

import com.entity.Person;

public interface PersonDao {

    //根据对象查询
public Person findMaster(Person person);
}

  

  5.DAO实现类  com.daoImpl

package com.daoImpl;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet; import com.dao.PersonDao;
import com.entity.Person;
import com.util.C3P0Util; public class PersonDaoImpl implements PersonDao { @Override
public Person findMaster(Person person) {
Connection conne = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
Person person2 = null;
String sql = "SELECT * FROM person WHERE name = ? AND password = ?"; try {
conne = C3P0Util.getConn(); // 建立了到特定数据库的连接之后,就可用该连接发送 SQL 语句。
pstmt = conne.prepareStatement(sql);
pstmt.setString(1, person.getName());
pstmt.setString(2, person.getPassword());
rs = pstmt.executeQuery(); if (rs.next()) {
person2 = new Person();
person2.setId(rs.getInt("id"));
person2.setName(rs.getString("name"));
person2.setPassword(rs.getString("password"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
C3P0Util.closeAll(rs, pstmt, conne);
}
return person2;
} }

  

  6.DAO工厂接口  com.service

package com.service;

import com.entity.Person;

public interface PersonService {
public boolean login (Person person);
}

  

  7.DAO工厂实现类  com.serviceImpl

package com.serviceImpl;

import com.dao.PersonDao;
import com.daoImpl.PersonDaoImpl;
import com.entity.Person;
import com.service.PersonService; public class PersonServiceImpl implements PersonService { @Override
public boolean login(Person person) {
boolean islogin = false;
PersonDao pd = new PersonDaoImpl();
Person ps2 = pd.findMaster(person);
if (null != ps2) {
islogin = true;
}
return islogin;
}
}

  

  8.测试

package com.test;

import java.util.Scanner;

import org.junit.Test;

import com.entity.Person;
import com.service.PersonService;
import com.serviceImpl.PersonServiceImpl; public class LoginTest {
@Test
public void loginTest() {
Scanner sc = new Scanner(System.in, "UTF-8");
System.out.println("请输入用户名");
String loginName = sc.next();
System.out.println("请输入密码");
String loginPassword = sc.next(); Person person = new Person();
person.setName(loginName);
person.setPassword(loginPassword); PersonService ps = new PersonServiceImpl();
boolean isLoginid = ps.login(person); if (isLoginid) {
System.out.println("登录成功");
} else {
System.out.println("用户名或密码错误");
}
}
}

运行结果如下:

DAO设计模式的更多相关文章

  1. JavaWeb技术(二):DAO设计模式

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

  2. Java Dao设计模式

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

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

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

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

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

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

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

  6. jsp DAO设计模式

    DAO(Data Access Objects)设计模式是属于J2EE体系架构中的数据层的操作. 一.为什么要用DAO? 比较在JSP页面中使用JDBC来连接数据库,这样导致了JSP页面中包含了大量的 ...

  7. 简单的Dao设计模式

    简单的DAO设计模式 这两天学习到了DAO(Data Access Object 数据存取对象)设计模式.想谈谈自己的感受,刚开始接触是感觉有点难,觉得自己逻辑理不清,主要是以前学的知识比较零散没有很 ...

  8. Java学习之DAO设计模式

    DAO设计模式是一个javaEE里的设计模式,DAO是Data Access Object 数据访问接口. 一个典型的DAO实现有三个组件: 1.一个DAO接口 2.一个DAO接口的具体类: 3.数据 ...

  9. JavaBean在DAO设计模式简介

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

随机推荐

  1. hadoop 笔记(zookeeper)

    1.安装 需要提前安装java环境,本文下载zookeeper-3.3.6.tar.gz包. 1.1 tar -zxvf zookeeper-3.3.6.tar.gz 1.2 修改conf中的zoo_ ...

  2. 写给.NET开发者的数据库Migration方案

    微软给我们提供了一种非常好用的数据库迁移方案,但是我发现周围的同学用的并不多,所以我还是想把这个方案整理一下..NET选手看过来,特别是还在通过手工执行脚本来迁移数据库的同学们,当然你也可以选择EF的 ...

  3. 用IntelliJ IDEA创建Gradle项目简单入门

    Gradle和Maven一样,是Java用得最多的构建工具之一,在Maven之前,解决jar包引用的问题真是令人抓狂,有了Maven后日子就好过起来了,而现在又有了Gradle,Maven有的功能它都 ...

  4. Spark笔记:复杂RDD的API的理解(上)

    本篇接着讲解RDD的API,讲解那些不是很容易理解的API,同时本篇文章还将展示如何将外部的函数引入到RDD的API里使用,最后通过对RDD的API深入学习,我们还讲讲一些和RDD开发相关的scala ...

  5. Web API 强势入门指南

    Web API是一个比较宽泛的概念.这里我们提到Web API特指ASP.NET Web API. 这篇文章中我们主要介绍Web API的主要功能以及与其他同类型框架的对比,最后通过一些相对复杂的实例 ...

  6. 前端进阶试题(css部分)

    一.css 40分 1. 什么是盒模型? 答: 2. Doctype的几种类型? 答:①.过渡的:②.严格的:③.框架的 更多详细介绍参考:资料 3. 如何布局左不动右边自适应的两列布局? 答:两种简 ...

  7. 【WCF】终结点的监听地址

    终结点主要作用是向客户端公开一些信息入口,通过这个入口,可以找到要调用的服务操作.通常,终结点会使用三个要素来表述,我记得老蒋(网名:Artech,在园子里可以找到他)在他有关WCF的书里,把这三要素 ...

  8. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  9. 读书笔记--SQL必知必会14--组合查询

    14.1 组合查询 复合查询(compound query)或并(union),SQL允许执行多个查询(多条SELECT语句),并将结果作为一个查询结果集返回. 应用场景: 在一个查询中从不同的表返回 ...

  10. Windows环境下vscode-go安装笔记

    一.介绍 对于Visual Studio Code开发工具,有一款优秀的GoLang插件,它的主页为:https://github.com/microsoft/vscode-go 这款插件的特性包括: ...