假设我们已经创建了实体模型,使用它的首选方法是什么?我个人无法下定决心..
使用ModelAdapter:
public statiс Product[] GetProducts()
{
using(Entities ctx = new Entities())
{
return ctx.Product.ToArray();
}
}
Product[] ps = ModelAdapter.GetProducts();
// ...
ModelAdapter.UpdateProduct(p);
使用上下文:
using(Entities ctx = new Entities())
{
Product[] ps = ctx.Product.ToArray();
// ...
ctx.SaveChanges();
}
混合模式,妥协?
扩展方法:
using(Entities ctx = new Entities())
{
Product[] ps = ctx.GetProducts();
// ...
ctx.UpdateProduct(p);
}
实际上现在,我正在尝试方法#4,将实用程序方法实现为上下文的扩展。所以我可以使用一个上下文,并对这个上下文进行多次调用。
答案 0 :(得分:6)
开发Web应用程序时,我一直在使用根据Web请求创建的共享上下文。然后,您可以使用“ModelAdapter”方法并保留封装,但仍然可以在相同的上下文中运行。我经常使用它并且没有遇到任何问题。
答案 1 :(得分:2)
通常使用符合您需求的任何内容,这些内容可维护且适合您应用程序的复杂性。你应该考虑几点:
答案 2 :(得分:0)
通常情况下,我会选择使用Repository pattern来抽象处理EF的复杂性,但只要我需要它就可以使用上下文。 (情景3)
“只要我需要它”,我的意思是只要服务电话需要。我不希望ObjectContext
持续多次服务调用,因为我需要处理它的状态。创建新ObjectContext
的成本可以忽略不计。
我认为在很多方面你的ModelAdapter
也会抽象出EF的复杂性,但是如果你决定坚持ObjectContext
,那么根据它的静态性质,你可能/会遇到并发场景中的问题。现在实施它的方式可能无法为您提供更复杂查询所需的灵活性(例如,加入Order< - > OrderDetail< - > Product。)。