J2EE基礎知識---PO/POJO/BO/DTO/VO的區別

1.PO :Persistent Object 持久化對象

.有時也被稱爲Data對象,對應數據庫中的entity,可以簡單認爲一個PO對應數據庫中的一條記錄。

.在hibernate持久化框架中與insert/delet操作密切相關。

PO中不應該包含任何對數據庫的操作。

PS:最形象的理解就是一個PO就是數據庫中的一條記錄。
好處是可以把一條記錄作爲一個對象處理,可以方便的轉爲其它對象。

2.POJO :Plain Ordinary Java Object 無規則簡單java對象(PS:Spring解密翻譯爲 Plain Old Java Object)

一箇中間對象,可以轉化爲PODTOVO

POJO持久化之後==PO

(在運行期,由Hibernate中的cglib動態把POJO轉換爲POPO相對於POJO會增加一些用來管理數據庫entity狀態的屬性和方法。PO對於programmer來說完全透明,由於是運行期生成PO,所以可以支持增量編譯,增量調試。)

POJO傳輸過程中==DTO

POJO用作表示層==VO

PO VO都應該屬於它。

PS:POJO是最常見最多變的對象,是一箇中間對象,也是我們最常打交道的對象。
一個POJO持久化以後就是PO
直接用它傳遞、傳遞過程中就是DTO
直接用來對應表示層就是VO


3.BO :Business Object 業務對象

封裝業務邏輯爲一個對象(可以包括多個PO,通常需要將BO轉化成PO,才能進行數據的持久化,反之,從DB中得到的PO,需要轉化成BO才能在業務層使用)。

關於BO主要有三種概念

、只包含業務對象的屬性;

、只包含業務方法;

、兩者都包含。

在實際使用中,認爲哪一種概念正確並不重要,關鍵是實際應用中適合自己項目的需要。

PS:主要作用是把業務邏輯封裝爲一個對象。這個對象可以包括一個或多個其它的對象。

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



4.VO :Value Object值對象 / View Object 表現層對象

.主要對應頁面顯示(web頁面/swtswing界面)的數據對象。

.可以和表對應,也可以不,這根據業務的需要。

 :在struts中,用ActionFormVO,需要做一個轉換,因爲PO是面向對象的,而ActionForm是和view對應的,要將幾個PO要顯示的屬性合成一個ActionForm,可以使用BeanUtilscopy方法。

PS:主要對應界面顯示的數據對象。對於一個WEB頁面,或者SWT、SWING的一個界面,用一個VO對象對應整個界面的值。


5.DTO (TO) :Data Transfer Object 數據傳輸對象

.用在需要跨進程或遠程傳輸時,它不應該包含業務邏輯。

.比如一張表有100個字段,那麼對應的PO就有100個屬性(大多數情況下,DTO 內的數據來自多個表)。但view層只需顯示10個字段,沒有必要把整個PO對象傳遞到client,這時我們就可以用只有這10個屬性的DTO來傳輸數據到client,這樣也不會暴露server端表結構。到達客戶端以後,如果用這個對象來對應界面顯示,那此時它的身份就轉爲VO

PS:主要用於遠程調用等需要大量傳輸對象的地方。
比如我們一張表有100個字段,那麼對應的PO就有100個屬性。
但是我們界面上只要顯示10個字段,
客戶端用WEB service來獲取數據,沒有必要把整個PO對象傳遞到客戶端,
這時我們就可以用只有這10個屬性的DTO來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端以後,如果用這個對象來對應界面顯示,那此時它的身份就轉爲VO

6.DAO :data access object數據訪問對象

.主要用來封裝對DB的訪問(CRUD操作)。

.通過接收Business層的數據,把POJO持久化爲PO

snap20070108.jpg




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 對象需要實現序列化接口。 
------------------------------------------------- 

java 的 (PO,VO,TO,BO,DAO,POJO) 解釋 

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


VO(value object) 值對象 
通常用於業務層之間的數據傳遞,和 PO 一樣也是僅僅包含數據而已。但應是抽象出的業務對象 , 可以和表對應 , 也可以不 , 這根據業務的需要 . 個人覺得同 DTO( 數據傳輸對象 ), 在 web 上傳遞。 

TO(Transfer Object) ,數據傳輸對象 
在應用程序不同 tie( 關係 ) 之間傳輸的對象 

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

QO :查詢對象 

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 操作 ...

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

DAO :數據訪問對象 —— 同時還有 DAO 模式 
DTO :數據傳輸對象 —— 同時還有 DTO 模式

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

參考:http://www.blogjava.net/luofeng225/archive/2009/03/28/262620.html

http://blog.csdn.net/geggegeda/article/details/3118452

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章