酷軟件建築師想要:)如何編程只與子實體創建的域實體
我有兩個實體:公司和用戶。
當用戶被添加到公司時,創建員工實體。員工代表用戶和公司之間的鏈接。沒有訪問列表的員工實體是無用的。換句話說,我有一些不變的:父實體(Employee)必須創建與子(訪問列表)。
我正在尋找desing解決方案來實現這個不變在C#代碼。
僱員實體具有所需參數的構造函數:
public class Employee
{
public Employee(EmployeeCreationParams creationParams)
{
this.Company = creationParams.Company;
this.User = creationCommand.User;
}
public Company { get; protected set; }
public User { get; protected set; }
// other state and logic
}
實體Child:
public class EmployeeAccessList
{
public EmployeeAccessList(EmployeeAccessListCreationParams creationParams)
{ /* initialization logic */ }
public Employee { get; protected set; }
public OperationEnum Operation { get; protected set; }
}
有通用庫服務:
public class Repository
{
public void Persist<TEntity>(TEntity entity)
{
// internal stuff
}
}
員工被創建,然後堅持:
var employee = new Employee(creationParams);
_repository.Persist(employee);
和ACL得到堅持,以及:
var accessList = CreateAccessList();
foreach(var acl in accessList)
{
_repository.Persist(acl);
}
我找不到注入的員工創建邏輯訪問列表創建登錄正確的方式。因此,父母和孩子都會成爲一個單位。
我嘗試添加子創建邏輯到父母的構造函數:
public class Employee
{
public Employee(EmployeeCreationParams creationParams)
{
this.Company = creationParams.Company;
this.User = creationCommand.User;
var accessList = CreateAccessList();
foreach(var acl in accessList)
{
_repository.Persist(acl);
}
}
}
..但這個解決方案看起來不正確的。子對象在父實體之前被持久化。
對於工廠建議+1,並引用了DDD Aggregate概念。 – tallseth
謝謝!對我來說,唯一困難的部分是知道聚合根實體的存儲庫(自動保留聚合中的所有實體)。你能否指導我解釋一下這個存儲庫想法和實現的一些資源(如果可能,使用實體框架)。 – Jekas
我不是EF專家,但我想這是在您調用SaveChanges()時由更改跟蹤器(ObjectContext/DBContext)處理的。有許多可能的Repository實現 - 其中有一個必須調用的顯式Save()方法來保存實體,當您添加()實體時內部調用SaveChanges(),另一些則沒有保存邏輯,將其留給他們的消費者決定何時保存。重要的是,Repository實現有一個對ORM變更跟蹤器/會話/對象池的引用,以便他們可以從中查詢,添加到它等。 – guillaume31