1. 程式人生 > >整理 JAVA 中 PO,VO,DO,TO,BO,DAO,POJO 的解釋

整理 JAVA 中 PO,VO,DO,TO,BO,DAO,POJO 的解釋

JAVA 中 PO,VO,TO,BO,DAO,POJO 解釋

花了一些時間整理了一些 JAVA 中這麼多 O ,,百度搜索,多有不足,有問題請聯絡評論


一、關於 PO 和 VO

(1)O/R Mapper 物件/關係 對映

O/R Mapping 是 Object Relational Mapping(物件關係對映)的縮寫。通俗點講,就是 將物件與關係資料庫繫結,用物件來表示關係資料

定義好所有的 mapping 之後,這個 O/R Mapper 可以幫我們做很多的工作。通過這些 mappings,這個 O/R Mapper 可以生成所有的關於物件儲存,刪除,讀取的 SQL 語句,我們不再需要寫那麼多行的 DAL 程式碼了。

在 O/R Mapping 的世界裡,有兩個基本的也是重要的概念需要了解,即 VO,PO
VO 值物件(Value Object),PO,持久物件(Persisent Object)

它們是由 一組屬性和屬性的 get 和 set 方法 組成。
從結構上看,它們並沒有什麼不同的地方。但從其意義和本質上來看是完全不同的。


(2)PO(persistant object) 持久物件

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

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

PO 的生命週期: 是向資料庫中新增新資料時建立,刪除資料庫中資料時削除的。並且它只能存活在一個數據庫連線中,斷開連線即被銷燬。

PO 是有狀態的,每個屬性代表其當前的狀態。它是物理資料的物件表示。使用它,可以使我們的程式與物理資料解耦,並且可以簡化物件資料與物理資料之間的轉換。

PO 的屬性是跟資料庫表的欄位一一對應的。

PO 物件需要實現序列化介面。

Hibernate 裡的實體 bean 就是個 PO,也叫 POJO;


(2)VO(value object) 值物件

VO 是值物件,精確點講它是 業務物件,是存活在業務層的,是業務邏輯使用的,它存活的目的就是 為資料提供一個生存的地方

VO 的屬性是根據當前業務的不同而不同的,也就是說,它的每一個屬性都一一對應當前業務邏輯所需要的資料的名稱。

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

!! 不同於 ViewObject 表現層物件

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


PO 是持久化物件,它只是將物理資料實體的一種物件表示,為什麼需要它?因為它可以簡化我們對於物理實體的瞭解和耦合,簡單地講,可以簡化物件的資料轉換為物理資料的程式設計。VO 是什麼?它是值物件,準確地講,它是業務物件,是生活在業務層的,是業務邏輯需要了解,需要使用的,再簡單地講,它是概念模型轉換得到的。

首先說 PO 和 VO 吧,它們的關係應該是相互獨立的,一個 VO 可以只是 PO 的部分,也可以是多個 PO 構成,同樣也可以等同於一個 PO(當然我是指他們的屬性)。正因為這樣,PO 獨立出來,資料持久層也就獨立出來了,它不會受到任何業務的干涉。又正因為這樣,業務邏輯層也獨立開來,它不會受到資料持久層的影響,業務層關心的只是業務邏輯的處理,至於怎麼存怎麼讀交給別人吧!不過,另外一點,如果我們沒有使用資料持久層,或者說沒有使用 Hibernate,那麼 PO 和 VO 也可以是同一個東西,雖然這並不好。

二、關於 DO,BO 和 DTO

(1)DO(Domain Object)領域物件
  就是從現實世界中抽象出來的有形或無形的業務實體。

(2)TO(Transfer Object) ,資料傳輸物件
  不同的應用程式之間傳輸的物件

(3)DTO(Data Transfer Object)資料傳輸物件
  這個概念來源於J2EE的設計模式,原來的目的是為了EJB的分散式應用提供粗粒度的資料實體,以減少分散式呼叫的次數,從而提高分散式呼叫的效能和降低網路負載,但在這裡,我泛指用於展示層與服務層之間的資料傳輸物件。

DTO 主要用於遠端呼叫等需要大量傳輸物件的地方。

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

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

BO 主要作用是把業務邏輯封裝為一個物件。這個物件可以包括一個或多個其它的物件。
比如一個簡歷,有教育經歷、工作經歷、社會關係等等。

我們可以把教育經歷對應一個 PO,工作經歷對應一個 PO,社會關係對應一個 PO。
建立一個對應簡歷的 BO 物件處理簡歷,每個 BO 包含這些 PO。
這樣處理業務邏輯時,我們就可以針對 BO 去處理。

三、關於 DAO,POJO

(1)DAO(data access object) 資料訪問物件

DAO:data access object 資料訪問物件。這個大家最熟悉,和上面幾個 O 區別最大,基本沒有互相轉化的可能性和必要.

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

主要用來封裝對資料庫的訪問。通過它可以把 POJO 持久化為 PO,用 PO 組裝出來 VO、在使用 hibernate 的時候我們會定義一些查詢的方法,這些方法寫在接口裡,可以有不同的實現類,而這個介面就可以說是個 DAO.

(2)POJO(plain ordinary java object) 簡單無規則 java 物件

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

POJO 是 DO/DTO/BO/VO的統稱。

感覺 POJO 是最常見最多變的物件,是一箇中間物件,也是我們最常打交道的物件。


簡單關係:

一個 POJO 持久化以後就是 PO
直接用它傳遞、傳遞過程中就是 DTO
直接用來對應表示層就是 VO

VO:值物件、檢視物件
PO:持久物件
DAO:資料訪問物件
DTO:資料傳輸物件

更多文章連結