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來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端之後,若是用這個對象來對應界面顯示,那此時它的身份就轉爲VOPOJO :plain ordinary java object 簡單java對象我的感受POJO是最多見最多變的對象,是一箇中間對象,也是咱們最常打交道的對象。一個POJO持久化之後就是PO直接用它傳遞、傳遞過程當中就是DTO直接用來對應表示層就是VODAO: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模式