原文地址:http://yinchunjian.iteye.com/blog/758196java
O是跟數據庫裏表的映射,一個表對應一個VO
DAO是用VO來訪問真實的表,對數據庫的操做都在DAO中完成
BO是業務層,作邏輯處理的web
VO , PO , BO , QO, DAO ,POJO,數據庫
O/R Mapping 是 Object Relational
Mapping (對象關係映射)的縮寫。通俗點講,就是將對象與關係數據庫綁定,用對象來表示關係數據。在 O/R
Mapping 的世界裏,有兩個基本的也是重要的東東須要瞭解,即 VO , PO 。設計模式
VO ,值對象 (Value Object) ,app
PO ,持久對象 (Persisent
Object) ,它們是由一組屬性和屬性的 get 和 set 方法組成。從結構上看,它們並無什麼不一樣的地方。但從其意義和本質上來看是徹底不一樣的。
1. VO 是用 new 關鍵字建立,由 GC 回收的。
PO 則是向數據庫中添加新數據時建立,刪除數據庫中數據時削除的。而且它只能存活在一個數據庫鏈接中,斷開鏈接即被銷燬。
2. VO 是值對象,精確點講它是業務對象,是存活在業務層的,是業務邏輯使用的,它存活的目的就是爲數據提供一個生存的地方。
PO 則是有狀態的,每一個屬性表明其當前的狀態。它是物理數據的對象表示。使用它,可使咱們的程序與物理數據解耦,而且能夠簡化對象數據與物理數據之間的轉換。
3. VO 的屬性是根據當前業務的不一樣而不一樣的,也就是說,它的每個屬性都一一對應當前業務邏輯所須要的數據的名稱。
PO 的屬性是跟數據庫表的字段一一對應的。
PO 對象須要實現序列化接口。
-------------------------------------------------框架
java 的 (PO,VO,TO,BO,DAO,POJO) 解釋
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) 數據訪問對象
是一個 sun 的一個標準 j2ee 設計模式, 這個模式中有個接口就是 DAO ,它負持久層的操做。爲業務層提供接口。此對象用於訪問數據庫。一般和 PO 結合使用, DAO 中包含了各類數據庫的操做方法。經過它的方法 , 結合 PO 對數據庫進行相關的操做。夾在業務邏輯與數據庫資源中間。配合 VO,
提供數據庫的 CRUD 操做 ...工具
DTO :
Data Transfer Object 數據傳輸對象
主要用於遠程調用等須要大量傳輸對象的地方。
好比咱們一張表有 100 個字段,那麼對應的 PO 就有 100 個屬性。
可是咱們界面上只要顯示 10 個字段,
客戶端用 WEB service 來獲取數據,沒有必要把整個 PO 對象傳遞到客戶端,
這時咱們就能夠用只有這 10 個屬性的 DTO 來傳遞結果到客戶端,這樣也不會暴露服務端表結構 . 到達客戶端之後,若是用這個對象來對應界面顯示,那此時它的身份就轉爲 VOpost
DAO :數據訪問對象 —— 同時還有 DAO 模式
DTO :數據傳輸對象 —— 同時還有 DTO 模式設計
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 建模框架對象