1. 程式人生 > 程式設計 >java的幾種物件(PO,VO,DAO,BO,POJO,DTO)解釋

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物件進行定義。

java物件應用圖
  如果沒有 VO 和 PO 的區別,那麼資料庫表結構的所有欄位就一覽無餘地展示到了前端,給後臺安全帶來很大的隱患,並且無法在網路傳輸中剝離冗餘資訊提高了使用者的頻寬成本

例項分析

  以一個例項來探討下 POJO 的使用。假設我們有一個面試系統,資料庫中儲存了很多面試題,通過 web 和 API 提供服務。可能會做如下的設計:

  1. 資料表:表中的面試題包括編號、題目、選項、答案、建立時間、修改時間;
  2. PO:包括題目、選項、答案、建立時間、修改時間;
  3. VO:題目、選項、答案、上一題URL、下一題URL;
  4. DTO:編號、題目、選項、答案、上一題編號、下一題編號;
  5. DAO:資料庫增刪改查方法;
  6. BO:業務基本操作。

  可以看到,進行 POJO 劃分後,我們得到了一個設計良好的架構,各層資料物件的修改完全可以控制在有限的範圍內。

參考文獻: