zoukankan      html  css  js  c++  java
  • 数据访问对象模式

    描述

    数据对象访问模式(DAO),用于把低级的数据访问API或操作从高级的业务服务中分离出来。该模式有三个成员:

    1、数据对象访问接口(DAO):该接口定义了在一个模型对象上要执行的标准操作。

    2、数据对象访问实体(DAOImpl):该实体实现了上述接口,并把其中的标准操作给实现;该实体类负责从数据源获取数据,数据源可以使数据库、文件或者其他的数据等。

    3、数据模型(model):是一个简单的POJO,包含了get和set方法来存储通过使用DAO类检索到的数据。

    实现

    我们将创建一个作为模型对象或数值对象的 Student 对象。StudentDao 是数据访问对象接口。StudentDaoImpl 是实现了数据访问对象接口的实体类。DaoPatternDemo,我们的演示类使用 StudentDao 来演示数据访问对象模式的用法。

    //student类的model
    public class Student {
       private String name;
       private int rollNo;
    
       Student(String name, int rollNo){
          this.name = name;
          this.rollNo = rollNo;
       }
    
       public String getName() {
          return name;
       }
    
       public void setName(String name) {
          this.name = name;
       }
    
       public int getRollNo() {
          return rollNo;
       }
    
       public void setRollNo(int rollNo) {
          this.rollNo = rollNo;
       }
    }
    
    //student的dao接口
    import java.util.List;
    
    public interface StudentDao {
       public List<Student> getAllStudents();
       public Student getStudent(int rollNo);
       public void updateStudent(Student student);
       public void deleteStudent(Student student);
    }
    
    //实现接口的实体类
    public class StudentDaoImpl implements StudentDao {
        
       //列表是当作一个数据库
       List<Student> students;
    
       public StudentDaoImpl(){
          students = new ArrayList<Student>();
          Student student1 = new Student("Robert",0);
          Student student2 = new Student("John",1);
          students.add(student1);
          students.add(student2);        
       }
       @Override
       public void deleteStudent(Student student) {
          students.remove(student.getRollNo());
          System.out.println("Student: Roll No " + student.getRollNo() 
             +", deleted from database");
       }
    
       //从数据库中检索学生名单
       @Override
       public List<Student> getAllStudents() {
          return students;
       }
    
       @Override
       public Student getStudent(int rollNo) {
          return students.get(rollNo);
       }
    
       @Override
       public void updateStudent(Student student) {
          students.get(student.getRollNo()).setName(student.getName());
          System.out.println("Student: Roll No " + student.getRollNo() 
             +", updated in the database");
       }
    }
    
    //测试
    public class DaoPatternDemo {
       public static void main(String[] args) {
          StudentDao studentDao = new StudentDaoImpl();
    
          //输出所有的学生
          for (Student student : studentDao.getAllStudents()) {
             System.out.println("Student: [RollNo : "
                +student.getRollNo()+", Name : "+student.getName()+" ]");
          }
    
    
          //更新学生
          Student student =studentDao.getAllStudents().get(0);
          student.setName("Michael");
          studentDao.updateStudent(student);
    
          //获取学生
          studentDao.getStudent(0);
          System.out.println("Student: [RollNo : "
             +student.getRollNo()+", Name : "+student.getName()+" ]");        
       }
    }
    
    //输出结果
    Student: [RollNo : 0, Name : Robert ]
    Student: [RollNo : 1, Name : John ]
    Student: Roll No 0, updated in the database
    Student: [RollNo : 0, Name : Michael ]
    

      

    代码来源: 特别感谢 菜鸟教程 java设计模式之数据访问对象模式

  • 相关阅读:
    英语初级学习系列-00-Name-介绍自己
    Solidworks实例学习
    数学——泰勒公式
    SolidWorks知识积累系列-01
    彻底弄懂HTTP缓存机制及原理
    基于 Pymsql 数据库连接池
    WEB框架之Flask
    Django使用消息提示简单的弹出个对话框
    代码的调试、运行
    微信公众号本地测试环境搭建(附带内网穿透工具使用)
  • 原文地址:https://www.cnblogs.com/K-artorias/p/7985912.html
Copyright © 2011-2022 走看看