[java]實體類(VO,DO,DTO,PO)的划分


實體類(VO,DO,DTO,PO)的划分

領域模型中的實體類

領域模型中的實體類分為四種類型:VO、DTO、DO、PO,各種實體類用於不同業務層次間的交互,並會在層次內實現實體類之間的轉化。

業務分層為:視圖層(VIEW+ACTION),服務層(SERVICE),持久層(DAO)

相應各層間實體的傳遞如下圖:

模型:

       下面以一個時序圖建立簡單模型來描述上述對象在三層架構應用中的位置

 

 

l         用戶發出請求(可能是填寫表單),表單的數據在展示層被匹配為VO。

l         展示層把VO轉換為服務層對應方法所要求的DTO,傳送給服務層。

l         服務層首先根據DTO的數據構造(或重建)一個DO,調用DO的業務方法完成具體業務。

l         服務層把DO轉換為持久層對應的PO(可以使用ORM工具,也可以不用),調用持久層的持久化方法,把PO傳遞給它,完成持久化操作。

l         對於一個逆向操作,如讀取數據,也是用類似的方式轉換和傳遞,略。

PO(persistant object) 持久對象

在 o/r 映射的時候出現的概念,如果沒有 o/r 映射,沒有這個概念存在了。通常對應數據模型 ( 數據庫 ), 本身還有部分業務邏輯的處理。可以看成是與數據庫中的表相映射的 java 對象。最簡單的 PO 就是對應數據庫中某個表中的一條記錄,多個記錄可以用 PO 的集合。 PO 中應該不包含任何對數據庫的操作。

DO(Domain Object)領域對象

就是從現實世界中抽象出來的有形或無形的業務實體。

TO(Transfer Object) ,數據傳輸對象

在應用程序不同 tie( 關系 ) 之間傳輸的對象

DTO(Data Transfer Object)數據傳輸對象

這個概念來源於J2EE的設計模式,原來的目的是為了EJB的分布式應用提供粗粒度的數據實體,以減少分布式調用的次數,從而提高分布式調用的性能和降低網絡負載,但在這里,我泛指用於展示層與服務層之間的數據傳輸對象。

VO(value object) 值對象

通常用於業務層之間的數據傳遞,和 PO 一樣也是僅僅包含數據而已。但應是抽象出的業務對象 , 可以和表對應 , 也可以不 , 這根據業務的需要 。用 new 關鍵字創建,由 GC 回收的。

BO(business object) 業務對象

從業務模型的角度看 , 見 UML 元件領域模型中的領域對象。封裝業務邏輯的 java 對象 , 通過調用 DAO 方法 , 結合 PO,VO 進行業務操作。 business object: 業務對象 主要作用是把業務邏輯封裝為一個對象。這個對象可以包括一個或多個其它的對象。 比如一個簡歷,有教育經歷、工作經歷、社會關系等等。 我們可以把教育經歷對應一個 PO ,工作經歷對應一個 PO ,社會關系對應一個 PO 。 建立一個對應簡歷的 BO 對象處理簡歷,每個 BO 包含這些 PO 。 這樣處理業務邏輯時,我們就可以針對 BO 去處理。

POJO(plain ordinary java object) 簡單無規則 java 對象

純的傳統意義的 java 對象。就是說在一些 Object/Relation Mapping 工具中,能夠做到維護數據庫表記錄的 persisent object 完全是一個符合 Java Bean 規范的純 Java 對象,沒有增加別的屬性和方法。我的理解就是最基本的 Java Bean ,只有屬性字段及 setter 和 getter 方法!。

DAO(data access object) 數據訪問對象

是一個 sun 的一個標准 j2ee 設計模式, 這個模式中有個接口就是 DAO ,它負持久層的操作。為業務層提供接口。此對象用於訪問數據庫。通常和 PO 結合使用, DAO 中包含了各種數據庫的操作方法。通過它的方法 , 結合 PO 對數據庫進行相關的操作。夾在業務邏輯與數據庫資源中間。配合 VO, 提供數據庫的 CRUD 操作.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM