java的幾種物件(PO,VO,DAO,BO,POJO,DTO)解釋
PO
PO(Persistant Object)可以看成是與資料庫中的表相對映的java物件。最簡單的PO就是對應資料庫中某個表中的一條記錄,多個記錄可以用PO的集合。PO中應該不包含任何對資料庫的操作。
好處就是可以把一條記錄作為一個物件處理,可以方便的轉為其他物件。
PO由一組屬性和屬性的get和set方法組成。
PO是在向資料庫中新增新資料時建立,刪除資料庫中資料時削除。並且PO只能存活在一個資料庫連線中,斷開連線就被銷燬。
PO是有狀態的,每個屬性代表其當前的狀態,他是物理資料的物件表示。使用它,可以使我們的程式與物理資料解耦,並且可以簡化物件資料與物理資料之間的轉換。
PO屬性是跟資料庫表的欄位一一對應的。PO物件需要實現序列化介面。
VO
value object值物件。通常用於業務層之間的資料傳遞,和PO一樣也是僅僅包含資料而已。但應是抽象出的業務物件,可以和表對應,也可以不,這根據業務的需要.個人覺得同DTO(資料傳輸物件),在web上傳遞。
VO由一組屬性和屬性的get和set方法組成。
VO是用new關鍵字建立,由GC回收。
VO是值物件,或者說是業務物件,是存活在業務層,是業務邏輯使用的,意義在於為微資料提供一個生存的地方。
VO的屬性是根據當前業務的不同而不同,即,它的每一個屬性都一一對應當前業務邏輯所需要的資料的名稱。
DAO
Data Access Object資料訪問物件,是sun的一個標準j2ee設計模式 .此物件用於訪問資料庫。通常和PO結合使用,DAO中包含了各種資料庫的操作方法。通過它的方法,結合PO對資料庫進行相關的操作。夾在業務邏輯與資料庫資源中間。配合VO,提供資料庫的CRUD操作。
BO
BO(Business Object)業務物件,封裝業務邏輯的java物件,通過呼叫DAO方法,結合PO,VO進行業務操作。這個物件可以包括一個或多個其它的物件。
比如一個簡歷,有教育經歷、工作經歷、 關係等等。我們可以把教育經歷對應一個PO,工作經歷對應一個PO, 關係對應一個PO。建立一個對應簡歷的BO物件處理簡歷,每個BO包含這些PO。這樣處理業務邏輯時,我們就可以針對BO去處理。
關於BO主要有三種概念 :
- 只包含業務物件的屬性;
- 只包含業務方法;
- 兩者都包含。
在實際使用中,認為哪一種概念正確並不重要,關鍵是實際應用中適合自己專案的需要
POJO
POJO(Plain Ordinary Java Object簡單無規則java物件)是純粹的傳統意義的java物件。就是說在一些Object Relation Mapping工具中,能夠做到維護資料庫表記錄的persisent object完全是一個符合Java Bean規範的純Java物件,沒有增加別的屬性和方法,即,最基本的Java Bean,只有屬性欄位及setter和getter方法!
- 一個POJO持久化以後就是PO;
- 直接用它傳遞,傳遞過程中就是DTO;
- 直接用來對應表示層就是VO。
DTO
DTO(Data Transfer Object,資料傳輸物件)主要用於遠端呼叫等需要大量傳輸物件的地方。 比如說,我們一張表有100個欄位,那麼對應的PO就有100個屬性。但是我們介面上只要顯示10個欄位, 客戶端用WEB service來獲取資料,沒有必要把整個PO物件傳遞到客戶端, 這時我們就可以用只有這10個屬性的DTO來傳遞結果到客戶端,這樣也不會暴露服務端表結構.到達客戶端以後,如果用這個物件來對應介面顯示,那此時它的身份就轉為VO。 DTO 是一組需要跨程式或網路邊界傳輸的聚合資料的簡單容器。它不應該包含業務邏輯,並將其行為限制為諸如內部一致性檢查和基本驗證之類的活動。注意,不要因實現這些方法而導致 DTO 依賴於任何新類。在設計資料傳輸物件時,您有兩種主要選擇:使用一般集合;或使用顯式的 getter 和 setter 方法建立自定義物件。
應用
不同型別的物件在架構設計中用於不同的用途,如下的分層架構表示了各個 POJO 的用途。是為了確保各個分層能夠很好地封裝自己的服務,有效地控制資訊的傳播,在分層結構中對POJO物件進行定義。
如果沒有 VO 和 PO 的區別,那麼資料庫表結構的所有欄位就一覽無餘地展示到了前端,給後臺安全帶來很大的隱患,並且無法在網路傳輸中剝離冗餘資訊提高了使用者的頻寬成本例項分析
以一個例項來探討下 POJO 的使用。假設我們有一個面試系統,資料庫中儲存了很多面試題,通過 web 和 API 提供服務。可能會做如下的設計:
- 資料表:表中的面試題包括編號、題目、選項、答案、建立時間、修改時間;
- PO:包括題目、選項、答案、建立時間、修改時間;
- VO:題目、選項、答案、上一題URL、下一題URL;
- DTO:編號、題目、選項、答案、上一題編號、下一題編號;
- DAO:資料庫增刪改查方法;
- BO:業務基本操作。
可以看到,進行 POJO 劃分後,我們得到了一個設計良好的架構,各層資料物件的修改完全可以控制在有限的範圍內。
參考文獻: