1. 程式人生 > >JAVA中(PO,VO,TO,BO,DAO,POJO)的解釋

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

轉:https://www.cnblogs.com/lenient/articles/1315336.html

 

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檢視物件 
PO:持久物件 
QO:查詢物件 
DAO:資料訪問物件——同時還有DAO模式 
DTO:資料傳輸物件——同時還有DTO模式