溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2020-09-24 13:15:56 來(lái)源:腳本之家 閱讀:197 作者:Rekent 欄目:編程語(yǔ)言

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

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

一般的DAO的封裝由以下另個(gè)原則:

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

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

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

下面展示一個(gè)DAO接口實(shí)例Manage:

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

下面我們針對(duì)一張具體的表對(duì)Manage創(chuàng)建實(shí)現(xiàn)類,比如表名為test,數(shù)據(jù)庫(kù)名為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;
    }
  }

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

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

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

總結(jié)

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

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI