DAO層,Service層,Controller層、View層 http://hovertree.com/hvtart/bjae/sko15s3g.htm 推薦:http://www.cnblogs.com/roucheng/p/chengxuyuan.html ...
DAO層,Service層,Controller層、View層
http://hovertree.com/hvtart/bjae/sko15s3g.htm
- DAO層:DAO層主要是做數據持久層的工作,負責與資料庫進行聯絡的一些任務都封裝在此,DAO層的設計首先是設計DAO的介面,然後在Spring的配置文件中定義此介面的實現類,然後就可在模塊中調用此介面來進行數據業務的處理,而不用關心此介面的具體實現類是哪個類,顯得結構非常清晰,DAO層的數據源配置,以及有關資料庫連接的參數都在Spring的配置文件中進行配置。
- Service層:Service層主要負責業務模塊的邏輯應用設計。同樣是首先設計介面,再設計其實現的類,接著再Spring的配置文件中配置其實現的關聯。這樣我們就可以在應用中調用Service介面來進行業務處理。Service層的業務實現,具體要調用到已定義的DAO層的介面,封裝Service層的業務邏輯有利於通用的業務邏輯的獨立性和重覆利用性,程式顯得非常簡潔。
- Controller層:Controller層負責具體的業務模塊流程的控制,在此層裡面要調用Serice層的介面來控制業務流程,控制的配置也同樣是在Spring的配置文件裡面進行,針對具體的業務流程,會有不同的控制器,我們具體的設計過程中可以將流程進行抽象歸納,設計出可以重覆利用的子單元流程模塊,這樣不僅使程式結構變得清晰,也大大減少了代碼量。 http://hovertree.com/hvtart/bjae/sko15s3g.htm
- View層 此層與控制層結合比較緊密,需要二者結合起來協同工發。View層主要負責前臺jsp頁面的表示,
- DAO層,Service層這兩個層次都可以單獨開發,互相的耦合度很低,完全可以獨立進行,這樣的一種模式在開發大項目的過程中尤其有優勢,Controller,View層因為耦合度比較高,因而要結合在一起開發,但是也可以看作一個整體獨立於前兩個層進行開發。這樣,在層與層之前我們只需要知道介面的定義,調用介面即可完成所需要的邏輯單元應用,一切顯得非常清晰簡單。
- DAO設計的總體規劃需要和設計的表,和實現類之間一一對應。
- DAO層所定義的介面里的方法都大同小異,這是由我們在DAO層對資料庫訪問的操作來決定的,對資料庫的操作,我們基本要用到的就是新增,更新,刪除,查詢等方法。因而DAO層裡面基本上都應該要涵蓋這些方法對應的操作。除此之外,可以定義一些自定義的特殊的對資料庫訪問的方法。
- Service邏輯層設計
- Service層是建立在DAO層之上的,建立了DAO層後才可以建立Service層,而Service層又是在Controller層之下的,因而Service層應該既調用DAO層的介面,又要提供介面給Controller層的類來進行調用,它剛好處於一個中間層的位置。每個模型都有一個Service介面,每個介面分別封裝各自的業務處理方法。
- 在DAO層定義的一些方法,在Service層並沒有使用,那為什麼還要在DAO層進行定義呢?這是由我們定義的需求邏輯所決定的。DAO層的操作 經過抽象後基本上都是通用的,因而我們在定義DAO層的時候可以將相關的方法定義完畢,這樣的好處是在對Service進行擴展的時候不需要再對DAO層進行修改,提高了程式的可擴展性。
推薦:http://www.cnblogs.com/roucheng/p/chengxuyuan.html