前言
一個項目中不一定都能用得上全部的分層規(guī)約,但十分有必要了解每一種的用法,便于去閱讀其他人的代碼。同樣的,雖然遵守規(guī)約寫代碼可能會略微拉低你寫代碼的速度(PS:多寫一些實體類),但越是規(guī)范化,模板化的東西,后期的維護成本和學習成本會越低。
《阿里巴巴Java開發(fā)規(guī)范》關(guān)于領(lǐng)域模型的部分介紹如下
分層領(lǐng)域模型規(guī)約:
DO(Data Object):此對象與數(shù)據(jù)庫表結(jié)構(gòu)一一對應(yīng),通過 DAO 層向上傳輸數(shù)據(jù)源對象。
DTO(Data Transfer Object):數(shù)據(jù)傳輸對象,Service 或 Manager 向外傳輸?shù)膶ο蟆?/p>
BO(Business Object):業(yè)務(wù)對象,由 Service 層輸出的封裝業(yè)務(wù)邏輯的對象。
AO(ApplicationObject):應(yīng)用對象,在Web層與Service層之間抽象的復(fù)用對象模型, 極為貼近展示層,復(fù)用度不高。
VO(View Object):顯示層對象,通常是 Web 向模板渲染引擎層傳輸?shù)膶ο蟆?/p>
Query:數(shù)據(jù)查詢對象,各層接收上層的查詢請求。注意超過 2 個參數(shù)的查詢封裝,禁止使用 Map 類來傳輸。
領(lǐng)域模型命名規(guī)約:
數(shù)據(jù)對象:xxxDO,xxx即為數(shù)據(jù)表名
數(shù)據(jù)傳輸對象:xxxDTO,xxx為業(yè)務(wù)領(lǐng)域相關(guān)的名稱。
展示對象:xxxVO,xxx一般為網(wǎng)頁名稱。
POJO:DO/DTO/BO/VO的統(tǒng)稱,禁止命名成xxxPOJO。
PO (persistant object )持久對象
可以看成是與數(shù)據(jù)庫中的表相映射的java對象。使用Hibernate來生成PO是不錯的選擇。
VO (value object) 值對象
通常用于業(yè)務(wù)層之間的數(shù)據(jù)傳遞,和PO一樣也是僅僅包含數(shù)據(jù)而已。但應(yīng)是抽象出的業(yè)務(wù)對象,可以和表對應(yīng),也可以不,這根據(jù)業(yè)務(wù)的需要。
PO只能用在數(shù)據(jù)層,VO用在商業(yè)邏輯層和表示層。各層操作屬于該層自己的數(shù)據(jù)對象,這樣就可以降低各層之間的耦合,便于以后系統(tǒng)的維護和擴展。
DAO (Data Access Objects) 數(shù)據(jù)訪問對象接口
DAO是Data Access Object數(shù)據(jù)訪問接口,數(shù)據(jù)訪問:顧名思義就是與數(shù)據(jù)庫打交道。夾在業(yè)務(wù)邏輯與數(shù)據(jù)庫資源中間。J2EE開發(fā)人員使用數(shù)據(jù)訪問對象(DAO)設(shè)計模式把底層的數(shù)據(jù)訪問邏輯和高層的商務(wù)邏輯分開。實現(xiàn)DAO模式能夠更加專注于編寫數(shù)據(jù)訪問代碼。
DAO模式是標準的J2EE設(shè)計模式之一,開發(fā)人員使用這個模式把底層的數(shù)據(jù)訪問操作和上層的商務(wù)邏輯分開。一個典型的DAO實現(xiàn)有下列幾個組件:
一個DAO工廠類;
一個DAO接口;
一個實現(xiàn)DAO接口的具體類;
數(shù)據(jù)傳遞對象(有些時候叫做值對象),具體的DAO類包含了從特定的數(shù)據(jù)源訪問數(shù)據(jù)的邏輯。
BO (Business Object) 業(yè)務(wù)對象層
表示應(yīng)用程序領(lǐng)域內(nèi)“事物”的所有實體類。這些實體類駐留在服務(wù)器上,并利用服務(wù)類來協(xié)助完成它們的職責。
DTO (Data Transfer Object) 數(shù)據(jù)傳輸對象
主要用于遠程調(diào)用等需要大量傳輸對象的地方。比如我們一張表有100個字段,那么對應(yīng)的PO就有100個屬性。但是我們界面上只要顯示10個字段,客戶端用WEB service來獲取數(shù)據(jù),沒有必要把整個PO對象傳遞到客戶端,這時我們就可以用只有這10個屬性的DTO來傳遞結(jié)果到客戶端,這樣也不會暴露服務(wù)端表結(jié)構(gòu)。到達客戶端以后,如果用這個對象來對應(yīng)界面顯示,那此時它的身份就轉(zhuǎn)為VO。
POJO (Plain Old Java Objects) 簡單的Java對象
實際就是普通JavaBeans,使用POJO名稱是為了避免和EJB混淆起來,而且簡稱比較直接。其中有一些屬性及其getter、setter方法的類,有時可以作為value object或dto(Data Transform Object)來使用。
當然,如果你有一個簡單的運算屬性也是可以的,但不允許有業(yè)務(wù)方法,也不能攜帶有connection之類的方法。
-
封裝
+關(guān)注
關(guān)注
126文章
7789瀏覽量
142728 -
數(shù)據(jù)庫
+關(guān)注
關(guān)注
7文章
3766瀏覽量
64277 -
代碼
+關(guān)注
關(guān)注
30文章
4751瀏覽量
68357
原文標題:別亂分層,PO、VO、DAO、BO、DTO、POJO 到底應(yīng)該用在哪里,你知道嗎?
文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論