淺談對(duì)于DAO設(shè)計(jì)模式的理解
為了降低耦合性,提出了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組件依賴(lài)于數(shù)據(jù)庫(kù)系統(tǒng),提供數(shù)據(jù)庫(kù)訪問(wèn)的接口。
一般的DAO的封裝由以下另個(gè)原則:
· 一個(gè)表對(duì)應(yīng)一個(gè)表,相應(yīng)地封裝一個(gè)DAO類(lèi)。
· 對(duì)于DAO接口,必須由具體的類(lèi)型定義。這樣可以避免被錯(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)類(lèi)即可。
下面展示一個(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)類(lèi),比如表名為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類(lèi)型的Collection,則從ResultSet里讀取出每一行的數(shù)據(jù)。
將一行的數(shù)據(jù),存入一個(gè)Java Bean中(為Bean 創(chuàng)建對(duì)應(yīng)類(lèi)型的成員變量),并將Set好的Bean存入Add入Collection。
再讀取下一行的數(shù)據(jù),重復(fù)操作,最后返回Collection即可。
總結(jié)
以上就是本文關(guān)于淺談對(duì)于DAO設(shè)計(jì)模式的理解的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以參閱本站:BaseJDBC和CRUDDAO的寫(xiě)法實(shí)例代碼、使用JDBC實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)對(duì)象層(DAO)代碼示例等,有什么問(wèn)題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家。感謝閱讀!
相關(guān)文章
Java?Excel?Poi字體顏色自定義設(shè)置代碼
最近項(xiàng)目使用POI按模板導(dǎo)出Excel,需要設(shè)置單元格的字體為紅色,下面這篇文章主要給大家介紹了關(guān)于Java?Excel?Poi字體顏色自定義設(shè)置的相關(guān)資料,需要的朋友可以參考下2024-01-01
為什么程序中突然多了 200 個(gè) Dubbo-thread 線程的說(shuō)明
這篇文章主要介紹了為什么程序中突然多了 200 個(gè) Dubbo-thread 線程的說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
Spring Boot詳解各類(lèi)請(qǐng)求和響應(yīng)的處理方法
平時(shí)只是在用SpringBoot框架,但并沒(méi)有詳細(xì)研究過(guò)請(qǐng)求和響應(yīng)執(zhí)行的一個(gè)具體過(guò)程,所以本文主要來(lái)梳理一下SpringBoot請(qǐng)求和響應(yīng)的處理過(guò)程2022-07-07
java定時(shí)任務(wù)實(shí)現(xiàn)的4種方式小結(jié)
這篇文章主要介紹了java定時(shí)任務(wù)實(shí)現(xiàn)的4種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
約定優(yōu)于配置_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
以前做項(xiàng)目,總是寫(xiě)Ant配置文件,滿足于自己更靈活的配置,而沒(méi)有去思考,這么做到底值不值得2017-08-08
Java Web實(shí)現(xiàn)文件下載和亂碼處理方法
文件上傳和下載是web開(kāi)發(fā)中常遇到的問(wèn)題。今天小編給大家分享下Java Web實(shí)現(xiàn)文件下載和亂碼處理方法的相關(guān)資料,需要的朋友可以參考下2016-10-10
SpringBoot為何可以使用Jar包啟動(dòng)詳解
springboot jar包啟動(dòng)腳本,適用于快速啟動(dòng),刪除,重啟,以及查看狀態(tài),下面這篇文章主要給大家介紹了關(guān)于SpringBoot為何可以使用Jar包啟動(dòng)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03
Java+opencv3.2.0實(shí)現(xiàn)hough直線檢測(cè)
這篇文章主要為大家詳細(xì)介紹了Java+opencv3.2.0之hough直線檢測(cè),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02

