通過一個實例來說明如何划分聚合與聚合根
場景:一個下訂單的業務,一個訂單必須有相應的客戶信息,訂單下有訂單項,每個訂單項必須有相應的產品信息,產品有分類的信息。
1.根據這個基本的需求,我們初步確定的實體、值對象與關聯關系為(這里采用EF的Model First):
2.經過業務深入分析,以及聚合與聚合根確定原則,最終我們確定的聚合與聚合根是(紅色代表聚合根,藍色代表聚合內的實體,灰色代表值對象):
划分與確定理由
1.訂單、客戶與產品都可以在不同的領域被獨立訪問到,所以應該是屬於不同聚合的聚合根。
2.訂單初看好像要依賴於客戶才能存在,其實不然,一是訂單的生命周期與客戶的生命周期不是一致的,二是訂單與客戶之間也沒有不變的一致性規則。
3.訂單只需要下訂單那個時刻客戶的姓名、電話與地址等相關信息,所以作了一個值對象保存那個時刻的客戶相關信息,因可能業務上需要通過訂單查詢客戶當前的信息,所以做了一個客戶ID關聯到客戶對象。
4.訂單項也只需要那個時刻的產品的名稱、單價等信息,所以作了一個值對象保存那個時刻的產品相關信息,因可能業務上需要通過訂單項查詢產品當前的信息,所以作了一個產品ID關聯到產品對象。
5.產品初看好像要依賴於產品類別,實際上產品類別只是對產品的一種划分,所以產品類別做成值對象,如果業務上要對某個產品類別進行促銷等業務邏輯,則產品類別應該划為一個單獨聚合的聚合根。
歡迎加入QQ討論群:309287205