天天看點

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

 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也可以是同一個東西,雖然這并不好。

----------------------------------------------------

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進行業務操作。

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

O/R Mapper 對象/關系 映射   

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

實體Model(實體模式) 

DAL(資料通路層) 

IDAL(接口層) 

DALFactory(類工廠) 

BLL(業務邏輯層) 

BOF     Business Object Framework       業務對象架構 

SOA     Service Orient Architecture     面向服務的設計 

EMF     Eclipse Model Framework         Eclipse模組化架構

----------------------------------------

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

DAO:

data access object資料通路對象

這個大家最熟悉,和上面幾個O差別最大,基本沒有互相轉化的可能性和必要.

主要用來封裝對資料庫的通路。通過它可以把POJO持久化為PO,用PO組裝出來VO、DTO

-----------------------------------------------------------------

PO:persistant object持久對象,可以看成是與資料庫中的表相映射的java對象。最簡單的PO就是對應資料庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對資料庫的操作.                                                                                        

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

DAO:data access object資料通路對象,此對象用于通路資料庫。通常和PO結合使用,DAO中包含了各種資料庫的操作方法。通過它的方法,結合PO對資料庫進行相關的操作.

BO:business object業務對象,封裝業務邏輯的java對象,通過調用DAO方法,結合PO,VO進行業務操作;

POJO:plain ordinary java object 簡單無規則java對象,我個人覺得它和其他不是一個層面上的東西,VO和PO應該都屬于它.

---------------------------------------------

VO:值對象、視圖對象

PO:持久對象

QO:查詢對象

DAO:資料通路對象

DTO:資料傳輸對象

struts 裡的 ActionForm 就是個VO;

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

hibernate裡的Criteria 就相當于一個QO;

在使用hibernate的時候我們會定義一些查詢的方法,這些方法寫在接口裡,可以有不同的實作類.而這個接口就可以說是個DAO.

個人認為QO和DTO差不多.

PO或叫BO,與資料庫最接近的一層,是ORM中的O,基本上是資料庫字段對應BO中的一個屬性,為了同步與安全性考慮,最好隻給DAO或者Service調用,而不要用packcode,backingBean,或者BO調。

DAO,資料通路層,把VO,backingBean中的對象可以放入。。。。

DTO,很少用,基本放入到DAO中,隻是起到過渡的作用。

QO,是把一些與持久性查詢操作與語句放入。。

VO,V層中用到的基本元素與方法等放其中。如果要其調用BO,則要做BO轉換VO,VO轉換BO操作。VO的好處是其頁面的元素屬性多于BO,可起到很好的作用。。。。

-----------------------------------------

樓上的不對吧,PO是持久化對象。BO=business object—業務對象。

PO可以嚴格對應資料庫表,一張表對映一個PO。

BO則是業務邏輯處理對象,我的了解是它裝滿了業務邏輯的處理,在業務邏輯複雜的應用中有用。

VO:value object值對象、view object視圖對象

DAO:資料通路對象——同時還有DAO模式

DTO:資料傳輸對象——同時還有DTO模式