(第4講)(PO,VO,TO,BO,DAO,POJO)解釋

http://www.cnblogs.com/yxnchinahlj/archive/2012/02/24/2366110.html

1、VO:即value Object,值對象

主要體現在視圖的對象,用於一個WEB頁面講整個頁面的屬性封裝成一個對象,然後用VO對象在控制層與視圖層進行傳輸交換。

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

2、DTO:data transfer Object,數據傳輸對象,是經過處理後的PO ,可能增加或減少PO的屬性

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

3、POJO(Plain Ordinary Java Object)簡單的Java對象, 其中有一些屬性及其getter、setter方法,不包含業務邏輯或持久邏輯等,不繼承類也不實現任何接口,即不是Javabean也不是Entitybean。

 POJO對象有時也被稱爲Data對象,大量應用於表現現實中的對象。如果項目中使用了Hibernate框架,有一個關聯的xml文件,使對象與數據庫中的表對應,對象的屬性與表中的字段相對應。有時可以作爲VO(value -object)或dto(Data Transform Object)來使用.當然,如果你有一個簡單的運算屬性也是可以的,但不允許有業務方法,也不能攜帶有connection之類的方法。

一個POJO持久化之後就是PO;

直接用它進行傳遞,傳遞過程中的就是DTO;

直接用來對應表示層就是VO,

4、PO = persisent object 持久對象

持久對象實際上必須對應數據庫中的entity,所以和POJO有所區別。比如說POJO是由new創建,由GC回收。但是持久對象是insert數據庫創建,由數據庫delete刪除的。基本上持久對象生命週期和數據庫密切相關。另外持久對象往往只能存在一個數據庫Connection之中,Connnection關閉以後,持久對象就不存在了,而POJO只要不被GC回收,總是存在的。由於存在諸多差別,因此持久對象PO(Persistent Object)在代碼上肯定和POJO不同,起碼PO相對於POJO會增加一些用來管理數據庫entity狀態的屬性和方法。而ORM追求的目標就是要PO在使用上儘量和POJO一致。
在o/r映射的時候出現的概念,如果沒有o/r映射,沒有這個概念存在了。通常對應數據模型(數據庫),本身還有部分業務邏輯的處理。可以看成是與數據庫中的表相映射的java對象。最簡單的PO就是對應數據庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對數據庫的操作。

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

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

6、BO(business object) 業務對象
從業務模型的角度看,見UML元件領域模型中的領域對象。封裝業務邏輯的java對象,通過調用DAO方法,結合PO,VO進行業務操作。

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

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


 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是持久化對象,它只是將物理數據實體的一種對象表示,爲什麼需要它?因爲它可以簡化我們對於物理實體的瞭解和耦合,簡單地講,可以簡化對象的數據轉換爲物理數據的編程。VO是什麼?它是值對象,準確地講,它是業務對象,是生活在業務層的,是業務邏輯需要了解,需要使用的,再簡單地講,它是概念模型轉換得到的。
首先說PO和VO吧,它們的關係應該是相互獨立的,一個VO可以只是PO的部分,也可以是多個PO構成,同樣也可以等同於一個PO(當然我是指他們的屬性)。正因爲這樣,PO獨立出來,數據持久層也就獨立出來了,它不會受到任何業務的干涉。又正因爲這樣,業務邏輯層也獨立開來,它不會受到數據持久層的影響,業務層關心的只是業務邏輯的處理,至於怎麼存怎麼讀交給別人吧!不過,另外一點,如果我們沒有使用數據持久層,或者說沒有使用hibernate,那麼PO和VO也可以是同一個東西,雖然這並不好。


 
   
發佈了84 篇原創文章 · 獲贊 21 · 訪問量 18萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章