標籤:
最近在給Android寫介面,其中伺服器資料需要定義VO(Value Object)對象進行封裝傳輸
對於VO ,PO , BO , QO,DAO,POJO概念還是比較模糊,所以在這裡記錄一下:
O/R Mapping 是 Object Relational Mapping (對象關係映射)的縮寫。通俗點講,就是將對象與關聯式資料庫綁定,用對象來表示關係資料。
在 O/R Mapping 的世界裡,有兩個基本的也是重要的東東需要瞭解,即 VO , PO。
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 進行業務操作。
business object: 業務對象
主要作用是把商務邏輯封裝為一個對象。這個對象可以包括一個或多個其它的對象。
比如一個簡曆,有教育經曆、工作經曆、社會關係等等。
我們可以把教育經曆對應一個 PO ,工作經曆對應一個 PO ,社會關係對應一個 PO 。
建立一個對應簡曆的 BO 對象處理簡曆,每個 BO 包含這些 PO 。
這樣處理商務邏輯時,我們就可以針對 BO 去處理。
QO :查詢對象
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 操作 ...
DTO : Data Transfer Object 資料轉送對象
主要用於遠程調用等需要大量傳輸對象的地方。
比如我們一張表有 100 個欄位,那麼對應的 PO 就有 100 個屬性。
但是我們介面上只要顯示 10 個欄位,
用戶端用 WEB service 來擷取資料,沒有必要把整個 PO 對象傳遞到用戶端,
這時我們就可以用只有這 10 個屬性的 DTO 來傳遞結果到用戶端,這樣也不會暴露服務端表結構 . 到達用戶端以後,如果用這個對象來對應介面顯示,那此時它的身份就轉為 VO
DAO :Data Access Objects —— 同時還有 DAO 模式
DTO :資料轉送對象 —— 同時還有 DTO 模式
O/R Mapper 對象 / 關係 映射
定義好所有的 mapping 之後,這個 O/R Mapper 可以幫我們做很多的工作。通過這些 mappings, 這個 O/R Mapper 可以產生所有的關於對象儲存,刪除,讀取的 SQL 語句,我們不再需要寫那麼多行的 DAL (資料訪問層)代碼了。
java 的 (PO,VO,TO,BO,DAO,POJO) 解釋