我正在开发一个软件,我有一些实体,例如:
public class Workspace
{
public int ID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public virtual List<Playground> Playground { get; set; }
public virtual List<Workspace> Children { get; set; }
public virtual List<Member> Members { get; set; }
public virtual Workspace Parent { get; set; }
}
public class Playground
{
public int ID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public virtual List<Service> Services { get; set; }
public virtual Workspace Workspace { get; set; }
}
public class Service
{
public int ID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public virtual Playground Playground { get; set; }
}
这些是我的EF4 POCO对象。我正在使用存储库模式和以下界面:
public interface IRepository<T>
{
void Add(T entity);
void Delete(T entity);
IEnumerable<T> Get(Expression<Func<T, bool>> expression);
IEnumerable<T> Get();
void Attach(T entity);
int Save();
}
存储库有一个内部ObjectContext。我有一个UnitOfWork,它包含我的存储库的实例,并负责保存对它们所做的更改。
到目前为止我做得对吗?
我正在实现这样的业务逻辑层:
public class DomainWorkspaceService : DomainServiceBase
{
public DomainWorkspaceService(Workspace workspace)
: base(UnitOfWorkFactory.GetInstance())
{
}
public void Create(Workspace workspace)
{
UoW.GetRepository<Workspace>().Add(workspace);
}
public void Delete(Workspace workspace)
{
var pservice = new DomainPlaygroundService();
foreach (var playground in workspace.Playground)
pservice.Delete(playground);
foreach (var child in workspace.Children)
Delete(child);
}
}
现在我不确定我是朝着正确的方向前进的。我的POCO(将)负责验证,并使我能够做类似
的事情SomeWorkspace.Children.Add(new Workspace {...});
由于这些对象与上下文相关联,因此当我保存它们时,对集合的更改是否也会保存在数据库中?
另外,我希望在没有Playground的工作区和服务的情况下无法创建我的Playgrounds。我应该在哪里创建和删除它们?
感谢。
答案 0 :(得分:1)
到目前为止,非常好。
您可能希望将Save
方法从存储库移到工作单元上。在实体框架中,您必须立即保存上下文中的所有更改;你不能每种类型做到这一点。将它放在Repository上意味着只保存对存储库的更改,这可能不正确。
您可能希望实现从工作空间到游乐场的级联作为数据库级联(实体框架将识别并支持),而不是手动编码它们。
是的,保存对上下文的更改将保存所有跟踪的更改,包括相关对象。
关于添加,如果你没有暴露ObjectContext,那么任何人都可以添加Playground的唯一方法是通过与你公开的对象的关系。