亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

JavaBean中DAO設計模式簡介

2019-11-14 15:36:52
字體:
來源:轉載
供稿:網友

一、信息系統的開發架構


客戶層-------顯示層-------業務層---------數據層---------數據庫

1.客戶層:客戶層就是客戶端,簡單的來說就是瀏覽器。

2.顯示層:jsp/Servlet,用于給瀏覽器顯示。

3.業務層:對于數據層的原子操作進行整合。

4.數據層:對于數據庫進行的原子操作,增加、刪除等;


二、DAO(Data access Object)介紹


DAO應用在數據層那塊,用于訪問數據庫,對數據庫進行操作的類。


三、DAO設計模式的結構


DAO設計模式一般分為幾個類:

1.VO(Value Object):一個用于存放網頁的一行數據即一條記錄的類,比如網頁要顯示一個用戶的信息,則這個類就是用戶的類。

2.DatabaseConnection:用于打開和關閉數據庫。

3.DAO接口:用于聲明對于數據庫的操作。

4.DAOImpl:必須實現DAO接口,真實實現DAO接口的函數,但是不包括數據庫的打開和關閉。

5.DAOPRoxy:也是實現DAO接口,但是只需要借助DAOImpl即可,但是包括數據庫的打開和關閉。

6.DAOFactory:工廠類,含有getInstance()創建一個Proxy類。


四、DAO的好處


DAO的好處就是提供給用戶的接口只有DAO的接口,所以如果用戶想添加數據,只需要調用create函數即可,不需要數據庫的操作。


五、DAO包命名


對于DAO,包的命名和類的命名一定要有層次。


六、實例解析


1.Emp.java   VO類

[java] view plaincopy    package org.vo;      import java.util.*;      public class Emp{          private int empno;          private String ename;          private String job;          private Date hireDate;          private float sal;          public Emp(){                        }          public int getEmpno(){              return empno;          }          public void setEmpno(int empno){              this.empno = empno;          }          public String getEname(){              return ename;          }          public void setEname(String ename){              this.ename = ename;          }          public Date getHireDate(){              return hireDate;          }          public void setHireDate(Date hireDate){              this.hireDate = hireDate;          }          public float getSal(){              return sal;          }          public void setSal(float sal){              this.sal = sal;          }          public String getJob(){              return job;          }          public void setJob(String job){              this.job = job;          }      }  

 

2.DatabaseConnection.java   連接數據庫操作

[java] view plaincopy
    package org.dbc;      import java.sql.*;      public class DatabaseConnection{          private Connection con = null;          private static final String DRIVER = "com.MySQL.jdbc.Driver";          private static final String USER = "root";          private static final String URL = "jdbc:mysql://localhost:3306/mldn";          private static final String PASS = "12345";          public DatabaseConnection()throws Exception{              Class.forName(DRIVER);              con = DriverManager.getConnection(URL,USER,PASS);          }          public Connection getConnection()throws Exception{              return con;          }          public void close()throws Exception{              if(con!=null){                  con.close();              }          }      }  

 

3.IEmpDAO.java   dao接口

[java] view plaincopy
    package org.dao;      import java.util.List;      import org.vo.*;      public interface IEmpDAO{          public boolean doCreate(Emp emp)throws Exception;          public List<Emp> findAll()throws Exception;          public Emp findById(int empno)throws Exception;      }  

 

4.EmpDAOImpl.java   接口的實現類

[java] view plaincopy
    package org.dao.impl;      import org.dao.*;      import java.sql.*;      import org.vo.*;      import java.util.*;      public class EmpDAOImpl implements IEmpDAO{          private Connection con;          private PreparedStatement stat = null;          public EmpDAOImpl(Connection con){              this.con = con;          }          public boolean doCreate(Emp emp)throws Exception{              String sql = "INSERT INTO emp(empno,ename,job,hiredate,sal) VALUES(?,?,?,?,?)";              stat = con.prepareStatement(sql);              stat.setInt(1,emp.getEmpno());              stat.setString(2,emp.getEname());              stat.setString(3,emp.getJob());              stat.setDate(4,new java.sql.Date(emp.getHireDate().getTime()));              stat.setFloat(5,emp.getSal());              int update = stat.executeUpdate();              if(update>0){                  return true;              }              else{                  return false;              }          }          public List<Emp> findAll()throws Exception{              String sql = "SELECT empno,ename,job,hiredate,sal FROM emp";              stat = con.prepareStatement(sql);              ResultSet rs = stat.executeQuery();              Emp emp = null;              List<Emp> list = new ArrayList<Emp>();              while(rs.next()){                  int empno = rs.getInt(1);                  String ename = rs.getString(2);                  String job = rs.getString(3);                  float sal = rs.getFloat(5);                  emp = new Emp();                  emp.setEmpno(empno);                  emp.setEname(ename);                  emp.setJob(job);                  emp.setHireDate(rs.getDate(4));                  emp.setSal(sal);                  list.add(emp);              }              return list;          }          public Emp findById(int empno)throws Exception{              String sql = "SELECT empno,ename,job,hiredate,sal FROM emp WHERE empno=?";              stat = con.prepareStatement(sql);              stat.setInt(1,empno);              ResultSet rs = stat.executeQuery();              Emp emp = null;              if(rs.next()){                  String ename = rs.getString(2);                  String job = rs.getString(3);                  float sal = rs.getFloat(5);                  emp = new Emp();                  emp.setEmpno(empno);                  emp.setEname(ename);                  emp.setJob(job);                  emp.setHireDate(rs.getDate(4));                  emp.setSal(sal);              }              return emp;          }      }  

 


5.EmpDAOProxy.java   數據庫開關

[java] view plaincopy
    package org.dao.impl;      import org.dao.*;      import java.sql.*;      import org.vo.*;      import java.util.*;      import org.dbc.*;      public class EmpDAOProxy implements IEmpDAO{          private DatabaseConnection dbc;          private IEmpDAO dao = null;          public EmpDAOProxy()throws Exception{              dbc = new DatabaseConnection();              dao = new EmpDAOImpl(dbc.getConnection());          }          public boolean doCreate(Emp emp)throws Exception{              boolean flag = false;              if(dao.findById(emp.getEmpno())==null){                  flag = dao.doCreate(emp);              }              dbc.close();              return flag;          }          public List<Emp> findAll()throws Exception{              List<Emp>list = dao.findAll();              dbc.close();              return list;          }          public Emp findById(int empno)throws Exception{              Emp emp = dao.findById(empno);              dbc.close();              return emp;          }      }  

 

6.DAOFactory.java  工廠類

[java] view plaincopy
    package org.dao.factory;      import org.dao.*;      import java.sql.*;      import org.vo.*;      import java.util.*;      import org.dbc.*;      import org.dao.impl.*;      public class DAOFactory{          public static IEmpDAO getInstance(){              IEmpDAO dao = null;              try{                  dao = new EmpDAOProxy();                  }              catch(Exception e){                  e.printStackTrace();              }              return dao;          }      }  

 


7.TestDAO.java

[java] view plaincopy
    package org.dao.test;      import org.dao.factory.*;      import org.vo.*;      import org.dao.*;      public class TestDAO{          public static void main(String args[])throws Exception{              Emp emp = null;              for(int i=0;i<5;i++){                  emp = new Emp();                  emp.setEmpno(i);                  emp.setEname("xiazdong-"+i);                  emp.setJob("stu-"+i);                  emp.setHireDate(new java.util.Date());                  emp.setSal(500*i);                  DAOFactory.getInstance().doCreate(emp);              }          }      }  

 


通過DAO設計模式,可以在JSP中屏蔽了數據庫連接的操作,達到JSP只負責顯示的效果。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人av色在线观看| 在线视频一区二区| 亚洲最大的成人网| 北条麻妃久久精品| 国产精品视频精品视频| 欧美丰满片xxx777| 91免费观看网站| 狠狠色香婷婷久久亚洲精品| 亚洲视频视频在线| 成人免费福利视频| 欧洲精品在线视频| 亚洲a区在线视频| 成人日韩av在线| 国产精品久久久久一区二区| 亚洲国产天堂网精品网站| 国产在线一区二区三区| 亚洲精品免费av| 国产精品久久久久久久久久免费| 亚洲精品aⅴ中文字幕乱码| 欧美中文字幕在线观看| 亚洲色图在线观看| 97国产精品人人爽人人做| 欧美午夜影院在线视频| 国产精品久久久久久久天堂| 亚洲欧美综合区自拍另类| 久久伊人91精品综合网站| 91精品国产综合久久香蕉| 亚洲护士老师的毛茸茸最新章节| 日韩精品视频在线播放| 亚洲综合中文字幕在线观看| 亚洲欧美999| 亚洲人成伊人成综合网久久久| 欧美中文字幕视频| 日韩午夜在线视频| 国内精品久久久| 亚洲一区二区在线播放| 91久久在线播放| 国产精品一区二区三区免费视频| 欧美性生交xxxxxdddd| 久久亚洲国产成人| 久久天天躁夜夜躁狠狠躁2022| 日韩欧美有码在线| 国产成人精品国内自产拍免费看| 国自在线精品视频| 隔壁老王国产在线精品| 中文字幕亚洲第一| 欧美乱妇高清无乱码| 青青久久av北条麻妃黑人| 久久久久久国产精品久久| 久热精品视频在线观看| 91亚洲精品在线观看| 中文字幕av一区二区三区谷原希美| 午夜精品国产精品大乳美女| 日韩高清中文字幕| 中文日韩在线视频| 国产精品久久久久久久7电影| 亚洲黄页网在线观看| 久久久久久久久久国产精品| 国产精品久久久久久久久免费| 69av在线播放| 中文.日本.精品| 国产亚洲视频中文字幕视频| 国产999精品久久久影片官网| 亚洲免费影视第一页| 日韩精品久久久久久久玫瑰园| 性欧美长视频免费观看不卡| 日本久久中文字幕| yw.139尤物在线精品视频| 国产欧美久久一区二区| 国产一区红桃视频| 亚洲男人天堂视频| 国产精品露脸av在线| 久久久精品国产一区二区| 国产日韩欧美电影在线观看| 国产日韩欧美中文在线播放| 永久免费看mv网站入口亚洲| 日韩网站免费观看高清| 欧美孕妇性xx| 日韩高清欧美高清| 欧美日韩国产一区二区三区| 蜜臀久久99精品久久久无需会员| 一区二区亚洲欧洲国产日韩| 色小说视频一区| 欧美激情一区二区三区在线视频观看| 最新69国产成人精品视频免费| 在线精品视频视频中文字幕| 亚洲欧美综合精品久久成人| 精品色蜜蜜精品视频在线观看| 日韩午夜在线视频| 欧美老女人性生活| 欧美亚洲国产日韩2020| 亚洲成人av在线| 91夜夜未满十八勿入爽爽影院| 日韩av有码在线| 国产欧美日韩亚洲精品| 久久免费视频这里只有精品| 国语自产精品视频在线看| 亚洲高清福利视频| 免费97视频在线精品国自产拍| 欧美色另类天堂2015| 在线视频国产日韩| 久久精品视频在线观看| yw.139尤物在线精品视频| 91精品国产高清久久久久久久久| 久久久在线免费观看| 欧美日韩精品国产| 久久影院中文字幕| 欧洲美女免费图片一区| 久久91亚洲精品中文字幕奶水| 在线日韩精品视频| 久久亚洲精品一区| 8090成年在线看片午夜| 欧美大码xxxx| 国产成人精品亚洲精品| 97成人精品区在线播放| 91亚洲精品久久久| 欧美专区在线观看| 97涩涩爰在线观看亚洲| 国产精品一区二区久久久| 精品中文字幕在线| 国产成人精品久久亚洲高清不卡| 中文字幕国产精品久久| 国产mv免费观看入口亚洲| 国产在线视频欧美| 久久久久久91| 中文国产成人精品| 国产在线播放不卡| 一本色道久久综合亚洲精品小说| 亚洲成人网在线观看| 日本免费一区二区三区视频观看| 成人黄色免费看| 欧美日韩国产页| 全球成人中文在线| 久久久视频免费观看| 久久久久国产一区二区三区| 69av在线视频| 日韩av色综合| 亚州精品天堂中文字幕| 亚洲精品wwww| 欧美激情第99页| 欧美www在线| 97视频在线观看视频免费视频| 91精品视频在线播放| 色播久久人人爽人人爽人人片视av| 日韩美女激情视频| 国产丝袜视频一区| 国产精品香蕉国产| 伊人伊人伊人久久| 青青青国产精品一区二区| 欧美肥老妇视频| 欧美国产日韩二区| 国产精品久久久久久影视| 欧美日韩在线免费| 日韩国产欧美精品一区二区三区| 日本精品一区二区三区在线| 日韩电影免费观看在线观看| 91网站免费看| 国产美女久久精品| 亚洲图片欧美日产| 国产乱人伦真实精品视频| 亚洲福利视频免费观看| 亚洲精品中文字幕女同| 国产精品久久久久高潮| 国产亚洲欧美视频|