主頁 > .NET開發 > 列出差異:DTO、VO、物體、域、模型

列出差異:DTO、VO、物體、域、模型

2022-04-28 18:48:50 .NET開發

現在我研究了基于JAVA平臺的Spring Boot。

我面臨的一個問題是如何區分 DTO、VO、Entity、Domain 和 Model。

老實說,這一切看起來都太相似了,無法區分。

我已經檢查了一些關于“DTO 和 VO 之間的差異”之類的 stackoverflow 答案。

但是,我仍然想知道它們在使用 Spring Boot 的開發人員方面有何不同。

uj5u.com熱心網友回復:

  • 物體 - 是具有 ID 的類。在關系資料庫的情況下,它通常是一個映射到具有一些主鍵的資料庫表的類。
  • DTO(資料傳輸物件)- 是一個可以很好地映射您通過網路發送的內容的類。例如,如果您交換 JSON 或 XML 資料,它通常具有足以填充這些請求/回應的欄位。請注意,它可能具有比物體更少或更多的欄位。
  • VO(值物件)是一個類值。例如,您可以創建像 Grams 或 Money 這樣的類——它將包含一些原語(例如一些double值),并且可以使用這些原語比較值物件。他們沒有資料庫 ID。它們有助于用與我們特定領域相關的更多面向物件的類替換原語。
  • 域模型包含所有物體和值物件。以及其他一些型別的類,具體取決于您使用的分類。

為了熟悉這些,您應該閱讀:

  • Fowler 的企業應用程式模式。提到價值物件和領域模型。
  • Eric Evans 的領域驅動設計。提到物體、價值物件和領域模型。
  • 并且可能熟悉 Java EE 設計模式。他們提到了 DTO。但這些都是寫得很糟糕的文章(如果它們仍然可以在互聯網上找到的話)。令人困惑的是,他們還有價值物件,它的定義與 DTO 非常相似,但沒有人使用 VO 的定義。

uj5u.com熱心網友回復:

這些只是文字,對于它們的確切含義沒有普遍的共識。

它們在不同的專案中具有不同的含義,而加入專案的一部分是學習那些特定于專案的定義。

此外,這些詞的定義 - 重疊,因為它們不是“一口氣”發明的,而是傳統上用于有影響力的書籍、博客等/

例如:

  • DTO 是 2000 年代初期的一個概念;那時,官方的 J2EE Java 強制使用(早已被遺忘和棄用的)“物體 EJB”與資料庫進行互動。事實證明,使用它們的最佳模式是創建額外的“傳輸物件”,僅用于管理 DAO 和“會話 ejb”(現在稱為“服務”)之間的通信。然后 Hibernate 出現了,帶來了“透明持久性”和“我們不需要單獨的 DTO,我們可以只使用 POJO 物體”的想法。不久之后,J, PA 誕生了。在一般情況下,“DTO”變成了“物體”,并且 DTO 這個名稱被重新用于“任何型別的資料,這些資料被打包用于與外部系統互動”。
  • VO 常用于“只讀型別的 DTO”。但有時,在領域驅動設計中,人們用這個術語來對比領域物件:“物體”是可以改變并保持“不變”的物件,而“價值物件”是不能改變的東西,因為它們會“變成別的東西”。例如,一輛車可以改變它的顏色,它仍然是“同一輛車”。另一方面,日期“1977-04-05”不能“變異”為“2011-04-05”,因為它只會變成其他日期。

要點:

  • 永遠不需要知道單詞的抽象定義。您將始終需要在背景關系中理解它們;
  • 不要相信(也不相信)那些試圖告訴你關于這些定義的“絕對真理”的人。你總是會發現同樣聰明的人聲稱完全不同的東西。
  • 理解軟體架構沒有王道,沒有“簡要總結”。它更像是哲學或歷史,而不是工程學。

uj5u.com熱心網友回復:

概括

  1. 一個物體
    是一個輕量級的持久域物件。通常,一個物體代表關系資料庫中的一個表,每個物體實體對應于該表中的一行。物體的主要編程工件是物體類,盡管物體可以使用幫助類。

  1. DTO(資料傳輸物件)
    是用于在層和層之間傳輸資料的容器。

    當您使用遠程介面時,每次呼叫都很昂貴,應該減少呼叫次數。解決方案是創建一個資料傳輸物件,該物件可以保存呼叫的所有資料。它需要可序列化才能通過連接。通常在服務器端使用匯編程式在 DTO 和任何域物件之間傳輸資料。它通常只不過是一堆欄位以及它們的 getter 和 setter。


  1. VO-A 值物件
    表示自己是一組固定的資料,類似于Java enum.

    值物件的標識基于它們的狀態而不是它們的物件標識,并且是不可變的。一個真實的例子是 Color.RED、Color.BLUE、SEX.FEMALE 等。


  1. 域模型
    包含所有物體和值物件。以及其他一些型別的類,具體取決于您使用的分類。

  2. Model
    定義模型屬性的持有者,主要用于向模型添加屬性。

  3. ModelMap
    是 Model 的擴展,能夠將屬性存盤在 map 和鏈方法呼叫中。

  4. ModelAndView
    是模型和視圖的持有者;它允許在一個回傳值中回傳模型和視圖。

    Model、ModelMap 和 ModelAndView 用于在 Spring MVC 應用程式中定義模型。


  1. DAO(資料訪問物件)或存盤庫
    資料訪問物件抽象并封裝了對資料源的所有訪問。DAO 管理與資料源的連接以獲取和存盤資料。

    DAO 實作了處理資料源所需的訪問機制。資料源可以是像 RDBMS 這樣的持久存盤,也可以是通過 REST 或 SOAP 訪問的業務服務。

    DAO 抽象了服務物件的底層資料訪問實作,以實作對資料源的透明訪問。該服務還將資料加載和存盤操作委托給 DAO。


  1. 服務: AService Layer從連接客戶端層的角度定義了應用程式的邊界及其可用操作集。

    它封裝了應用程式的業務邏輯,控制事務并在其操作的實作中協調回應。

    盡管將業務邏輯放在這里是在 EJB 1.x 和 2.x 時代引入的一種反模式。最好將與業務相關的功能放入域模型中。閱讀貧血與豐富模型:貧血架構 - 測驗的敵人



圖層

在了解 Spring Boot 架構之前,您必須了解其中存在的不同層和類。Spring Boot中有四層如下:

  1. 表示層
    表示層處理 HTTP 請求,將 JSON 引數轉換為物件,并對請求進行身份驗證并將其傳遞給業務層。簡而言之,它由視圖即前端部分組成。

  2. 業務層
    業務層處理所有業務邏輯。它由服務類組成,并使用資料訪問層提供的服務。它還執行授權和驗證。

  3. 持久性和資料庫層
    持久性層包含所有存盤邏輯,并將業務物件從資料庫行轉換為資料庫行。這也是執行 CRUD(創建、檢索、更新、洗掉)操作的地方。

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/466493.html

標籤:爪哇 弹簧靴 dto

上一篇:使用DockerCompose覆寫Spring活動組態檔

下一篇:在Java中將2個請求類合并為一個具有必填欄位的類?

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more