java的幾種物件(PO,VO,DAO,BO,POJO,DTO)解釋

水桶前輩發表於2018-11-28

一、PO:persistant object 持久物件,可以看成是與資料庫中的表相對映的java物件。最簡單的PO就是對應資料庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對資料庫的操作。 
二、VO:value object值物件。通常用於業務層之間的資料傳遞,和PO一樣也是僅僅包含資料而已。但應是抽象出的業務物件,可以和表對應,也可以不,這根據業務的需要.個人覺得同DTO(資料傳輸物件),在web上傳遞。

三、DAO:data access object 資料訪問物件,是一個sun的一個標準j2ee設計模式 .此物件用於訪問資料庫。通常和PO結合使用,DAO中包含了各種資料庫的操作方法。通過它的方法,結合PO對資料庫進行相關的操作。夾在業務邏輯與資料 庫資源中間。配合VO, 
提供資料庫的CRUD操作...

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

(關於BO主要有三種概念 :
1 、只包含業務物件的屬性; 
2 、只包含業務方法; 
3 、兩者都包含。 
在實際使用中,認為哪一種概念正確並不重要,關鍵是實際應用中適合自己專案的需要)

五、POJO:plain ordinary java object 簡單無規則java物件,我個人覺得它和其他不是一個層面上的東西,VO和PO應該都屬於它。

六、DTO:Data Transfer Object(資料傳輸物件)DTO 是一組需要跨程式或網路邊界傳輸的聚合資料的簡單容器。它不應該包含業務邏輯,並將其行為限制為諸如內部一致性檢查和基本驗證之類的活動。注意,不要因實 現這些方法而導致 DTO 依賴於任何新類。在設計資料傳輸物件時,您有兩種主要選擇:使用一般集合;或使用顯式的 getter 和 setter 方法建立自定義物件。(資料:http://baike.baidu.com/view/160599.htm)


O/R Mapping 是 Object Relational Mapping(物件關係對映)的縮寫。通俗點講,就是將物件與關聯式資料庫繫結,用物件來表示關係資料。在O/R Mapping的世界裡,有兩個基本的也是重要的東東需要了解,即VO,PO。 
  VO,值物件(Value Object),PO,持久物件(Persisent Object),它們是由一組屬性和屬性的get和set方法組成。從結構上看,它們並沒有什麼不同的地方。但從其意義和本質上來看是完全不同的。


1.VO是用new關鍵字建立,由GC回收的。 
  PO則是向資料庫中新增新資料時建立,刪除資料庫中資料時削除的。並且它只能存活在一個資料庫連線中,斷開連線即被銷燬。 
2.VO是值物件,精確點講它是業務物件,是存活在業務層的,是業務邏輯使用的,它存活的目的就是為資料提供一個生存的地方。 
  PO則是有狀態的,每個屬性代表其當前的狀態。它是物理資料的物件表示。使用它,可以使我們的程式與物理資料解耦,並且可以簡化物件資料與物理資料之間的轉換。 
3.VO的屬性是根據當前業務的不同而不同的,也就是說,它的每一個屬性都一一對應當前業務邏輯所需要的資料的名稱。 
  PO的屬性是跟資料庫表的欄位一一對應的。PO物件需要實現序列化介面。

 

 

PO:
persistant object持久物件
最形象的理解就是一個PO就是資料庫中的一條記錄。
好處是可以把一條記錄作為一個物件處理,可以方便的轉為其它物件。

 


BO:
business object業務物件
主要作用是把業務邏輯封裝為一個物件。這個物件可以包括一個或多個其它的物件。
比如一個簡歷,有教育經歷、工作經歷、  關係等等。
我們可以把教育經歷對應一個PO,工作經歷對應一個PO,  關係對應一個PO。
建立一個對應簡歷的BO物件處理簡歷,每個BO包含這些PO。
這樣處理業務邏輯時,我們就可以針對BO去處理。

 


VO :
value object值物件
ViewObject表現層物件
主要對應介面顯示的資料物件。對於一個WEB頁面,或者SWT、SWING的一個介面,用一個VO物件對應整個介面的值。

 

DTO :
Data Transfer Object資料傳輸物件
主要用於遠端呼叫等需要大量傳輸物件的地方。
比如我們一張表有100個欄位,那麼對應的PO就有100個屬性。
但是我們介面上只要顯示10個欄位,
客戶端用WEB service來獲取資料,沒有必要把整個PO物件傳遞到客戶端,
這時我們就可以用只有這10個屬性的DTO來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端以後,如果用這個物件來對應介面顯示,那此時它的身份就轉為VO

 


POJO :
plain ordinary java object 簡單java物件
個人感覺POJO是最常見最多變的物件,是一箇中間物件,也是我們最常打交道的物件。
一個POJO持久化以後就是PO
直接用它傳遞、傳遞過程中就是DTO
直接用來對應表示層就是VO

相關文章