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

來源:互聯網
上載者:User

標籤:擷取資料   過程   代碼   code   應用   for   常見   建立   是什麼   

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) Data Access Objects 是一個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 objectData Access Objects 這個大家最熟悉,和上面幾個O區別最大,基本沒有互相轉化可能性和必要. 主要用來封裝對資料庫訪問。通過它可以把POJO持久化為PO,用PO組裝出來VO、DTO

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

PO:persistant object持久對象,可以看成是與資料庫中表相映射java對象。最簡單PO就是對應資料庫中某個表中一條記錄,多個記錄可以用PO集合。PO中應該不包含任何對資料庫操作.                                                                                                VO:value object值對象。通常用於業務層之間資料傳遞,和PO一樣也是僅僅包含資料而已。但應是抽象出業務對象,可以和表對應,也可以不,這根據業務需要.個人覺得同DTO(資料轉送對象),在web上傳遞.

DAO:data access objectData Access Objects,此對象用於訪問資料庫。通常和PO結合使用,DAO中包含了各種資料庫操作方法。通過它方法,結合PO對資料庫進行相關操作.

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

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

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

VO:值對象、視圖對象

PO:持久對象

QO:查詢對象

DAO:Data Access Objects

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:Data Access Objects——同時還有DAO模式

DTO:資料轉送對象——同時還有DTO模式

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.