领域驱动设计之聚合与聚合根实例一
生活随笔
收集整理的這篇文章主要介紹了
领域驱动设计之聚合与聚合根实例一
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
通過一個實例來說明如何劃分聚合與聚合根
場景:一個下訂單的業務,一個訂單必須有相應的客戶信息,訂單下有訂單項,每個訂單項必須有相應的產品信息,產品有分類的信息。
1.根據這個基本的需求,我們初步確定的實體、值對象與關聯關系為(這里采用EF的Model First):
2.經過業務深入分析,以及聚合與聚合根確定原則,最終我們確定的聚合與聚合根是(紅色代表聚合根,藍色代表聚合內的實體,灰色代表值對象):
劃分與確定理由
1.訂單、客戶與產品都可以在不同的領域被獨立訪問到,所以應該是屬于不同聚合的聚合根。
2.訂單初看好像要依賴于客戶才能存在,其實不然,一是訂單的生命周期與客戶的生命周期不是一致的,二是訂單與客戶之間也沒有不變的一致性規則。
3.訂單只需要下訂單那個時刻客戶的姓名、電話與地址等相關信息,所以作了一個值對象保存那個時刻的客戶相關信息,因可能業務上需要通過訂單查詢客戶當前的信息,所以做了一個客戶ID關聯到客戶對象。
4.訂單項也只需要那個時刻的產品的名稱、單價等信息,所以作了一個值對象保存那個時刻的產品相關信息,因可能業務上需要通過訂單項查詢產品當前的信息,所以作了一個產品ID關聯到產品對象。
5.產品初看好像要依賴于產品類別,實際上產品類別只是對產品的一種劃分,所以產品類別做成值對象,如果業務上要對某個產品類別進行促銷等業務邏輯,則產品類別應該劃為一個單獨聚合的聚合根。
總結
以上是生活随笔為你收集整理的领域驱动设计之聚合与聚合根实例一的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 聚合(根)、实体、值对象精炼思考总结
- 下一篇: 多线程访问全局变量和局部变量