經過一個實例來講明如何劃分聚合與聚合根對象
場景:一個下訂單的業務,一個訂單必須有相應的客戶信息,訂單下有訂單項,每一個訂單項必須有相應的產品信息,產品有分類的信息。blog
1.根據這個基本的需求,咱們初步肯定的實體、值對象與關聯關係爲(這裏採用EF的Model First):生命週期
2.通過業務深刻分析,以及聚合與聚合根肯定原則,最終咱們肯定的聚合與聚合根是(紅色表明聚合根,藍色表明聚合內的實體,灰色表明值對象):產品
劃分與肯定理由
1.訂單、客戶與產品均可以在不一樣的領域被獨立訪問到,因此應該是屬於不一樣聚合的聚合根。im
2.訂單初看好像要依賴於客戶才能存在,其實否則,一是訂單的生命週期與客戶的生命週期不是一致的,二是訂單與客戶之間也沒有不變的一致性規則。查詢
3.訂單隻須要下訂單那個時刻客戶的姓名、電話與地址等相關信息,因此做了一個值對象保存那個時刻的客戶相關信息,因可能業務上須要經過訂單查詢客戶當前的信息,因此作了一個客戶ID關聯到客戶對象。img
4.訂單項也只須要那個時刻的產品的名稱、單價等信息,因此做了一個值對象保存那個時刻的產品相關信息,因可能業務上須要經過訂單項查詢產品當前的信息,因此做了一個產品ID關聯到產品對象。co
5.產品初看好像要依賴於產品類別,實際上產品類別只是對產品的一種劃分,因此產品類別作成值對象,若是業務上要對某個產品類別進行促銷等業務邏輯,則產品類別應該劃爲一個單獨聚合的聚合根。ps