1

我正在尝试为实体框架创建一个通用的 Get 方法,它具有动态WhereInclude. 我正在使用下面的代码,但是当我尝试访问包含列表中的导航属性时,我收到有关关闭对象上下文的错误

.Include()应该加载这些对象,所以我不需要保持 ObjectContext 打开?

public static List<T> GetList<T>(Func<T, bool> where, string[] includes)
    where T : EntityObject
{
    using (var context = new TContext())
    {
        ObjectQuery<T> q = context.CreateObjectSet<T>();
        foreach (string navProperty in includes)
        {
            q.Include(navProperty);
        }

        return q.Where<T>(where).ToList();
    }
}

导致错误的代码:

var x = DAL<MyContext>.GetList<MyEntity>(
                p => p.Id == 1
                , new string[]{ "Type" } );

var y = x.Type;  // Throws an error that context has been closed

我觉得我在这里一定犯了某种愚蠢的错误,因为我是 EF 的新手,并且仍在努力解决这个问题。

4

1 回答 1

3

您没有重新分配q- 这应该可以解决它:

    foreach (string navProperty in includes)
    {
        q = q.Include(navProperty);
    }

请记住,您正在使用每个返回一个 IQueryable<T>的扩展方法,而不是修改原始方法。

于 2011-08-23T16:09:38.920 回答