欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談對于DAO設(shè)計模式的理解

 更新時間:2017年10月18日 11:38:07   作者:Rekent  
這篇文章主要介紹了淺談對于DAO設(shè)計模式的理解,小編覺得挺不錯的,這里分享給大家,供需要的朋友參考。

為了降低耦合性,提出了DAO封裝數(shù)據(jù)庫操作的設(shè)計模式。

它可以實現(xiàn)業(yè)務(wù)邏輯與數(shù)據(jù)庫訪問相分離。相對來說,數(shù)據(jù)庫是比較穩(wěn)定的,其中DAO組件依賴于數(shù)據(jù)庫系統(tǒng),提供數(shù)據(jù)庫訪問的接口。

一般的DAO的封裝由以下另個原則:

 · 一個表對應(yīng)一個表,相應(yīng)地封裝一個DAO類。
 · 對于DAO接口,必須由具體的類型定義。這樣可以避免被錯誤地調(diào)用。

 在DAO模式中,將對數(shù)據(jù)的持久化抽取到DAO層,暴露出Service層讓程序員使用,這樣,一方面避免了業(yè)務(wù)代碼中混雜JDBC調(diào)用語句,使得業(yè)務(wù)落實實現(xiàn)更加清晰。

 通常我們創(chuàng)建一個包,用于保存DAO接口,再創(chuàng)建一個包,用于保存DAO接口的實現(xiàn)類即可。

下面展示一個DAO接口實例Manage:

public interface Manage {
  /*插入(insert)操作--->方法名(插入的數(shù)據(jù)1,插入的數(shù)據(jù)2,……)-->返回T|F*/
  public boolean insert(String name,String classes,String score);
  /*獲取全表(select *)操作-->利用Bean,一行對應(yīng)一個Bean-->返回一個承載Bean的Collection*/
  public Collection select();
  /*刪除(delete)操作-->方法名(where處需要的數(shù)據(jù))--->返回T|F*/
  public boolean delete(String id);
  /*獲取指定行對象---->方法名(where處需要的數(shù)據(jù))---->返回一個承載Bean的List*/
  public List up_select(String id);
  /*修改指定行對象---->方法名(修改數(shù)據(jù)1,修改數(shù)據(jù)2,……,where處需要的數(shù)據(jù))---->返回T|F*/
  public boolean update(String name,String classes,String id);
}

下面我們針對一張具體的表對Manage創(chuàng)建實現(xiàn)類,比如表名為test,數(shù)據(jù)庫名為bean。

public class ManageInfo implements Manage {
  final private String url="jdbc:mysql://localhost:3306/bean";
  final private String user="root";
  final private String password="root";
  @Override
  public boolean insert(String name, String classes, String score) throws Exception {
    Class.forName("com.mysql.jdbc.Driver");
    Connection conn = DriverManager.getConnection(url, user, password);
    String sql="insert into test(name,classes,score) Values(?,?,?)";
    PreparedStatement st=conn.prepareStatement(sql);
    st.setString(1,name);
    st.setString(2,classes);
    st.setString(3,score);
    int count=st.executeUpdate();
    if(count<=1){
      return true;
    }else {
      return false;
    }
  }

其余實現(xiàn)近乎相同,若返回Bean類型的Collection,則從ResultSet里讀取出每一行的數(shù)據(jù)。

將一行的數(shù)據(jù),存入一個Java Bean中(為Bean 創(chuàng)建對應(yīng)類型的成員變量),并將Set好的Bean存入Add入Collection。

再讀取下一行的數(shù)據(jù),重復(fù)操作,最后返回Collection即可。

總結(jié)

以上就是本文關(guān)于淺談對于DAO設(shè)計模式的理解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以參閱本站:BaseJDBC和CRUDDAO的寫法實例代碼、使用JDBC實現(xiàn)數(shù)據(jù)訪問對象層(DAO)代碼示例等,有什么問題可以隨時留言,小編會及時回復(fù)大家。感謝閱讀!

相關(guān)文章

  • 徹底解決Spring MVC中文亂碼問題的方案

    徹底解決Spring MVC中文亂碼問題的方案

    這篇文章主要介紹了徹底解決Spring MVC中文亂碼問題的方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-11-11
  • springboot2.5.0和redis整合配置詳解

    springboot2.5.0和redis整合配置詳解

    本篇文章向大家介紹springboot2.5.0 整合 redis 配置方法,教大家在pom添加依賴的方法如何調(diào)用redis,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-06-06
  • 詳解Springboot應(yīng)用啟動以及關(guān)閉時完成某些操作

    詳解Springboot應(yīng)用啟動以及關(guān)閉時完成某些操作

    這篇文章主要介紹了詳解Springboot應(yīng)用啟動以及關(guān)閉時完成某些操作,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • JAVA 數(shù)據(jù)結(jié)構(gòu)之Queue處理實例代碼

    JAVA 數(shù)據(jù)結(jié)構(gòu)之Queue處理實例代碼

    這篇文章主要介紹了JAVA 數(shù)據(jù)結(jié)構(gòu)之Queue處理實例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • Java求字符串長度的方法舉例

    Java求字符串長度的方法舉例

    這篇文章主要給大家介紹了關(guān)于Java求字符串長度的相關(guān)資料,Java中的字符串是一種常見的數(shù)據(jù)類型,用于表示文本數(shù)據(jù),文中給出了詳細(xì)的代碼實例,需要的朋友可以參考下
    2023-10-10
  • Spring注解@Import原理解析

    Spring注解@Import原理解析

    這篇文章主要為大家介紹了Spring注解@Import原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • spring boot打jar包發(fā)布的方法

    spring boot打jar包發(fā)布的方法

    這篇文章主要介紹了spring boot打jar包發(fā)布的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • idea sql的xml文件出現(xiàn)紅色警告符的處理方式

    idea sql的xml文件出現(xiàn)紅色警告符的處理方式

    這篇文章主要介紹了idea sql的xml文件出現(xiàn)紅色警告符處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 利用spring aop實現(xiàn)動態(tài)代理

    利用spring aop實現(xiàn)動態(tài)代理

    這篇文章主要為大家詳細(xì)介紹了利用spring aop實現(xiàn)動態(tài)代理的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • IntelliJ IDEA 構(gòu)建maven多模塊工程項目(詳細(xì)多圖)

    IntelliJ IDEA 構(gòu)建maven多模塊工程項目(詳細(xì)多圖)

    這篇文章主要介紹了IntelliJ IDEA 構(gòu)建maven多模塊工程項目(詳細(xì)多圖),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評論