java的幾種物件(PO,VO,DAO,BO,POJO,DTO)解釋
一、PO:persistant object 持久物件,可以看成是與資料庫中的表相對映的java物件。最簡單的PO就是對應資料庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對資料庫的操作。
二、VO:value object值物件。通常用於業務層之間的資料傳遞,和PO一樣也是僅僅包含資料而已。但應是抽象出的業務物件,可以和表對應,也可以不,這根據業務的需要.個人覺得同DTO(資料傳輸物件),在web上傳遞。
三、DAO:data access object 資料訪問物件,是一個sun的一個標準j2ee設計模式 .此物件用於訪問資料庫。通常和PO結合使用,DAO中包含了各種資料庫的操作方法。通過它的方法,結合PO對資料庫進行相關的操作。夾在業務邏輯與資料 庫資源中間。配合VO,
提供資料庫的CRUD操作...
四、BO(business object) 業務物件
從業務模型的角度看,見UML元件領域模型中的領域物件。封裝業務邏輯的java物件,通過呼叫DAO方法,結合PO,VO進行業務操作。這個物件可以包括一個或多個其它的物件。
比如一個簡歷,有教育經歷、工作經歷、 關係等等。
我們可以把教育經歷對應一個PO,工作經歷對應一個PO, 關係對應一個PO。
建立一個對應簡歷的BO物件處理簡歷,每個BO包含這些PO。
這樣處理業務邏輯時,我們就可以針對BO去處理。
(關於BO主要有三種概念 :
1 、只包含業務物件的屬性;
2 、只包含業務方法;
3 、兩者都包含。
在實際使用中,認為哪一種概念正確並不重要,關鍵是實際應用中適合自己專案的需要)
五、POJO:plain ordinary java object 簡單無規則java物件,我個人覺得它和其他不是一個層面上的東西,VO和PO應該都屬於它。
六、DTO:Data Transfer Object(資料傳輸物件)DTO 是一組需要跨程式或網路邊界傳輸的聚合資料的簡單容器。它不應該包含業務邏輯,並將其行為限制為諸如內部一致性檢查和基本驗證之類的活動。注意,不要因實 現這些方法而導致 DTO 依賴於任何新類。在設計資料傳輸物件時,您有兩種主要選擇:使用一般集合;或使用顯式的 getter 和 setter 方法建立自定義物件。(資料:http://baike.baidu.com/view/160599.htm)
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:
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
相關文章
- java的(PO,VO,TO,BO,DAO,POJO)解釋JavaPOJO
- PO/POJO/BO/DTO/VO/DAO的區別POJO
- 概念POJO、DTO、DAO、PO、BO、VO、ENTITY詳解POJO
- Java中PO、DO、TO、DTO、 VO、 BO、POJO 、DAO的概念JavaPOJO
- Java開發中的幾種物件的說明(PO,VO,DTO,BO,POJO,DAO,SAO等)Java物件POJO
- Java中 VO、 PO、DO、DTO、 BO、 QO、DAO、POJO的概念JavaPOJO
- 詳述 PO VO BO DTO DAO 和 POJO 的概念及區別POJO
- vo bo dto pojo(entity)POJO
- DO、DTO、BO、AO、VO、POJO定義規範POJO
- JAVA進階:VO(DTO)與PO(DAO)之間的轉換Java
- Java | DO / DTO / BO / VO的區別Java
- 專案中DO、PO、BO,DTO、VO的概念與意義
- VO/DTO/DO/PO通俗的解釋加上自己的理解
- 一款 IDEA 外掛幫你優雅轉化 DTO、VO、BO、PO、DOIdea
- 淺析VO、DTO、DO、PO的概念、區別和用處
- 轉載:領域模型中的實體類分為四種型別:VO、DTO、DO、PO模型型別
- DTO轉VO工具
- javabean:VO和POJO的區別?JavaBeanPOJO
- session bean + dao +vo ???SessionBean
- 後端開發基礎概念 Entity,DAO,DO,DTO,VO, Service,Controller後端Controller
- VO(檢視模型) 與 DTO(資料傳輸物件)的區別模型物件
- 關於對於Java中Entity以及VO,以及DTO中Request物件序列化的學習Java物件
- PO,VO 之懶載入疑問
- 簡化Java資料傳輸物件DTO:DTO-Free JavaJava物件
- Java中的幾種註釋Java
- Java值物件或DTO克隆工具Java物件
- hibernate中po物件的三種狀態分析物件
- SLSB+BO+DAO+Hibernate部署打包的問題
- 五種方法建立java物件,你知道幾種呢?Java物件
- 建立物件的幾種模式物件模式
- Java 自動釋放鎖的幾種實現Java
- 我寫了個IDEA開源外掛,vo2dto 一鍵生成物件轉換Idea物件
- Java for迴圈的幾種用法詳解Java
- js建立物件的幾種方式JS物件
- javascript建立物件的幾種方式JavaScript物件
- [php]建立物件的幾種形式PHP物件
- JS建立物件幾種不同方法詳解JS物件
- Java 的幾種版本Java