1. 程式人生 > >領域驅動設計之聚合與聚合根例項一(訂單)

領域驅動設計之聚合與聚合根例項一(訂單)

通過一個例項來說明如何劃分聚合與聚合根

場景:一個下訂單的業務,一個訂單必須有相應的客戶資訊,訂單下有訂單項,每個訂單項必須有相應的產品資訊,產品有分類的資訊。

1.根據這個基本的需求,我們初步確定的實體、值物件與關聯關係為(這裡採用EF的Model First):

2.經過業務深入分析,以及聚合與聚合根確定原則,最終我們確定的聚合與聚合根是(紅色代表聚合根,藍色代表聚合內的實體,灰色代表值物件):

劃分與確定理由
1.訂單、客戶與產品都可以在不同的領域被獨立訪問到,所以應該是屬於不同聚合的聚合根。

2.訂單初看好像要依賴於客戶才能存在,其實不然,一是訂單的生命週期與客戶的生命週期不是一致的,二是訂單與客戶之間也沒有不變的一致性規則。

3.訂單隻需要下訂單那個時刻客戶的姓名、電話與地址等相關資訊,所以作了一個值物件儲存那個時刻的客戶相關資訊,因可能業務上需要通過訂單查詢客戶當前的資訊,所以做了一個客戶ID關聯到客戶物件。

4.訂單項也只需要那個時刻的產品的名稱、單價等資訊,所以作了一個值物件儲存那個時刻的產品相關資訊,因可能業務上需要通過訂單項查詢產品當前的資訊,所以作了一個產品ID關聯到產品物件。

5.產品初看好像要依賴於產品類別,實際上產品類別只是對產品的一種劃分,所以產品類別做成值物件,如果業務上要對某個產品類別進行促銷等業務邏輯,則產品類別應該劃為一個單獨聚合的聚合根。