實體類(VO,DO,DTO)的劃分

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。

從領域建模中的實體劃分、項目中的實際應用情況兩個角度,對這幾個概念進行簡析。

得出的主要結論是:在項目應用中,VO對應于頁面上需要顯示的數據(表單),DO對應于數據庫中存儲的數據(數據表),DTO對應于除二者之外需要進行傳遞的數據。

一、實體類

百度百科中對于實體類的定義如下:

實體類的主要職責是存儲和管理系統內部的信息,它也可以有行為,甚至很復雜的行為,但這些行為必須與它所代表的實體對象密切相關。

根據以上定義,我們可以了解到,實體類有兩方面內容,存儲數據和執行數據本身相關的操作。這兩方面內容對應到實現上,最簡單的實體類是POJO類,含有屬性及屬性對應的set和get方法,實體類常見的方法還有用于輸出自身數據的toString方法。

實體類(VO,DO,DTO)的劃分
?

?

二、領域模型中的實體類

領域模型中的實體類分為四種類型:VO、DTO、DO、PO,各種實體類用于不同業務層次間的交互,并會在層次內實現實體類之間的轉化。

業務分層為:視圖層(VIEW+ACTION),服務層(SERVICE),持久層(DAO)

相應各層間實體的傳遞如下圖:

實體類(VO,DO,DTO)的劃分

?

項目中我們并沒有嚴格遵循這種傳遞關系,但這種和業務層次的關聯對我們理解各實體類的作用是有幫助的。(我們沒有接觸到PO的原因,我理解為ORM對PO進行了封裝)

以下是資料的原文,上圖是基于此繪制的:

概念:

VO(View Object):視圖對象,用于展示層,它的作用是把某個指定頁面(或組件)的所有數據封裝起來。

DTO(Data Transfer Object):數據傳輸對象,這個概念來源于J2EE的設計模式,原來的目的是為了EJB的分布式應用提供粗粒度的數據實體,以減少分布式調用的次數,從而提高分布式調用的性能和降低網絡負載,但在這里,我泛指用于展示層與服務層之間的數據傳輸對象。

DO(Domain Object):領域對象,就是從現實世界中抽象出來的有形或無形的業務實體。

PO(Persistent Object):持久化對象,它跟持久層(通常是關系型數據庫)的數據結構形成一 一對應的映射關系,如果持久層是關系型數據庫,那么,數據表中的每個字段(或若干個)就對應PO的一個(或若干個)屬性。

模型:

???????下面以一個時序圖建立簡單模型來描述上述對象在三層架構應用中的位置

l????????用戶發出請求(可能是填寫表單),表單的數據在展示層被匹配為VO。

l????????展示層把VO轉換為服務層對應方法所要求的DTO,傳送給服務層。

l????????服務層首先根據DTO的數據構造(或重建)一個DO,調用DO的業務方法完成具體業務。

l????????服務層把DO轉換為持久層對應的PO(可以使用ORM工具,也可以不用),調用持久層的持久化方法,把PO傳遞給它,完成持久化操作。

l????????對于一個逆向操作,如讀取數據,也是用類似的方式轉換和傳遞,略。

三、項目中的實體類

項目中常見的實體類有VO,DO和DTO,命名規則也常是以相應字符串結尾,如*VO.Java。但是DTO不總是遵循這個規則,而通常與他的用途有關,如寫成*Query.java,表示存儲了一個查詢條件。項目中實體類出現的業務層次也沒有這么嚴格,例如我們可以在視圖層就組裝一個DO,也可以將一個VO從持久層傳出來,所以與業務分層相關聯的劃分方法顯得有些冗余。從項目代碼中抽象出的理解是:VO對應于頁面上需要顯示的數據,DO對應于數據庫中存儲的數據,DTO對應于除二者之外需要進行傳遞的數據。

?

PO(persistant object) 持久對象

?

在 o/r 映射的時候出現的概念,如果沒有 o/r 映射,沒有這個概念存在了。通常對應數據模型 ( 數據庫 ), 本身還有部分業務邏輯的處理。可以看成是與數據庫中的表相映射的 java 對象。最簡單的 PO 就是對應數據庫中某個表中的一條記錄,多個記錄可以用 PO 的集合。 PO 中應該不包含任何對數據庫的操作。

DO(Domain Object)領域對象

就是從現實世界中抽象出來的有形或無形的業務實體。

TO(Transfer Object) ,數據傳輸對象

在應用程序不同 tie( 關系 ) 之間傳輸的對象

DTO(Data Transfer Object)數據傳輸對象

這個概念來源于J2EE的設計模式,原來的目的是為了EJB的分布式應用提供粗粒度的數據實體,以減少分布式調用的次數,從而提高分布式調用的性能和降低網絡負載,但在這里,我泛指用于展示層與服務層之間的數據傳輸對象。

VO(value object) 值對象

通常用于業務層之間的數據傳遞,和 PO 一樣也是僅僅包含數據而已。但應是抽象出的業務對象 , 可以和表對應 , 也可以不 , 這根據業務的需要 。用 new 關鍵字創建,由 GC 回收的。

BO(business object) 業務對象

從業務模型的角度看 , 見 UML 元件領域模型中的領域對象。封裝業務邏輯的 java 對象 , 通過調用 DAO 方法 , 結合 PO,VO 進行業務操作。 business object: 業務對象 主要作用是把業務邏輯封裝為一個對象。這個對象可以包括一個或多個其它的對象。 比如一個簡歷,有教育經歷、工作經歷、社會關系等等。 我們可以把教育經歷對應一個 PO ,工作經歷對應一個 PO ,社會關系對應一個 PO 。 建立一個對應簡歷的 BO 對象處理簡歷,每個 BO 包含這些 PO 。 這樣處理業務邏輯時,我們就可以針對 BO 去處理。

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 操作.

?

轉自:https://blog.csdn.net/wangxin1982314/article/details/51954264

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/448717.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/448717.shtml
英文地址,請注明出處:http://en.pswp.cn/news/448717.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

IIS新建站點服務器,localhost能登錄但是IP訪問登錄不了。

IIS服務器新建站點之后,瀏覽頁面,服務器本地是可以登錄,但是localhost換成IP就無法訪問。其他站點IP卻可以訪問。 1.如果瀏覽直接失敗,說明端口號需要更換。 2.如果出現IP不能訪問,localhost能訪問,需要在高…

eclipse問題_Alt+/不給提示,只補充代碼問題的解決方案

今天用eclipse敲代碼的時候遇到的問題 我還以為是沖突什么的 還重新裝了軟件 最后才發現原來是快捷鍵設置的問題 解決方案: 1:打開菜單window→Preferences,然后在窗口的左側樹選擇General->Keys 2:在下圖中的5框的地方輸入“w…

領域驅動設計:淺析 VO、DTO、DO、PO 概念、區別、用處

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 本篇文章主要討論一下我們經常會用到的一些對象:VO、DTO、DO和PO。 由于不同的項目和開發人員有不同的命名習慣&#xff0c…

動腦的生活教育

心理學家華生曾經說過:“如果給我一打孩子,我可以把他們變成律師、醫師、科學家,或是強盜、土匪。”華生認為,教育孩子就如同馬戲團的馴獸師訓練野獸一樣,是“刺激”與“反應”的聯結,不需要任何的“思考”…

前端知識點回顧之重點篇——CORS

CORS(cross origin resource sharing)跨域資源共享 來源:http://www.ruanyifeng.com/blog/2016/04/cors.html 它允許瀏覽器向跨源服務器,發出XMLHttpRequest請求,從而克服了AJAX只能同源使用的限制。 簡介 CORS需要瀏覽…

案例:隱秘而低調的內存泄露(OOM)

內存泄露測試的整個過程如下:在手機里啟動被測APP并打開DDMS。在DDMS中選中【com.example.android.hcgallery】之后單擊按鈕【show heap updates】,然后切換到標簽頁【VM Heap】,再單擊按鈕【Cause GC】。不斷操作APP,并觀察Heap。…

員工價值——如何體現自己價值,如何被自己的領導認可

到公司工作快三年了,比我后來的同事陸續得到了升職的機會,我卻原地不動,心里頗不是滋味。終于有一天,冒著被解聘的危險,我找到老板理論。 “老板,我有過遲到、早退或亂章違紀的現象嗎?”我問。 …

java: PO,VO,TO,BO,DAO,POJO 解釋

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 O/R Mapping 是 Object Relational Mapping(對象關系映射)的縮寫。通俗點講,就是將對象與關系數據庫綁…

[譯]JavaScript 究竟是如何工作的?(第一部分)

原文地址:How Does JavaScript Really Work? (Part 1)原文作者:Priyesh Patel如果你是一個 JS 開發者或者是正在學習這門語言的學生,很大概率上你會遇到雙字母詞"V8"。在這篇文章中,我將會為你簡述不同的 JS 引擎并深入…

vue實戰(9):總結二

整理前一段所做的工作內容 0.其它 vue實戰(1):準備與資料整理vue實戰(2):初始化項目、搭建底部導航路由vue實戰(3):底部導航顯示、搭建各模塊靜態頁面、添加登錄頁頁面與…

一名IT從業者的英語口語能力成長路徑

這篇文章是我最近十天口語系列文章的合輯,文章比較長,一萬五千余字。但是系統化地歸納了自己十多年的英語尤其是口語方面的學習經歷與總結思考。我不是個純粹的英語專業學生,我甚至不是任何英語相關專業的學生,但是我和英語卻有著…

解決:SpringBoot 錯誤:Caused by: org.yaml.snakeyaml.scanner.ScannerException

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 錯誤: Caused by: org.yaml.snakeyaml.scanner.ScannerException: while scanning for the next tokenfound character that cannot s…

好程序員前端分享使用JS開發簡單的音樂播放器

好程序員前端分享使用JS開發簡單的音樂播放器,最近,我們在教學生使用JavaScript,今天就帶大家開發一款簡單的音樂播放器。首先,最終效果如圖所示:首先,我們來編寫html界面index.html,代碼如下:&…

學生管理系統stuSystem函數

void stuSystem(){ struct student *head,*stu; int lookup_num; int Delete_num; int Modify_num; char ckeya; int istate0; do { system("cls"); //vc清屏函數&#xff0c;包含在#include<stdlib.h>中 printf(" 歡迎進入學生管理系統&#xff01;\n&q…

OpenCL用于計算機領域的13個經典案例

摘要&#xff1a;當使用加速器和OpenCL時&#xff0c;哪種類型的算法更加快速&#xff1f;來自弗吉尼亞理工大學的Wu Feng教授和他的團隊例舉了一份算法列表&#xff0c;分享了OpenCL常被用于計算機領域的13個經典案例。 哪種算法可以最好的映射GPU及矢量處理器呢&#xff1f;…

版本控制:集中式(SVN) vs 分布式(GIT)

Linus一直痛恨的CVS及SVN都是集中式的版本控制系統&#xff0c;而Git是分布式版本控制系統&#xff0c;集中式和分布式版本控制系統有什么區別呢&#xff1f; 先說集中式版本控制系統&#xff0c;版本庫是集中存放在中央服務器的&#xff0c;而干活的時候&#xff0c;用的都是…

Knative 核心概念介紹:Build、Serving 和 Eventing 三大核心組件

為什么80%的碼農都做不了架構師&#xff1f;>>> 作者| 阿里云智能事業群高級開發工程師 元毅 Knative 主要由 Build、Serving 和 Eventing 三大核心組件構成。Knative 正是依靠這三個核心組件&#xff0c;驅動著 Knative 這艘 Serverless 巨輪前行。下面讓我們來分…

樹莓派基金會來號召用鍵盤生物學家研究企鵝

倫敦動物學會&#xff08;Zoological Society of London&#xff09;于2014年&#xff0c;與伍茲霍爾海洋研究所和牛津大學等組織合作監控企鵝的計劃Penguin Lifelines有了新進展&#xff0c;倫敦動物學會現與其他動物保護組織合作Penguin Watch項目&#xff0c;邀請民眾在網上…

BlockingCollectionT 類實現 列隊操作

官方文檔 為實現 IProducerConsumerCollection<T> 的線程安全集合提供阻塞和限制功能。 通過 BlockingCollection<T> 實現列隊調用函數 建立全局變量 BlockingCollection<string> blockingCollection new BlockingCollection<string>(); 建立調用函數…

Git 版本回退

現在&#xff0c;你已經學會了修改文件&#xff0c;然后把修改提交到Git版本庫&#xff0c;現在&#xff0c;再練習一次&#xff0c;修改readme.txt文件如下&#xff1a; Git is a distributed version control system. Git is free software distributed under the GPL.然后嘗…