c# - 即使在 ObjectContext.ContextOptions.LazyLoadingEnabled = false 时也会延迟加载导航属性

标签 c# entity-framework entity-framework-4 lazy-loading

我注释掉了从我的 ObjectContext 类的所有构造函数重载启用延迟加载的代码行,但是当我迭代导航属性时,迭代成功。为什么?

这是相关的代码。

    public MyExpensesEntities() : 
                 base("name=MyExpensesEntities", "MyExpensesEntities")
    {
        // this.ContextOptions.LazyLoadingEnabled = true;
        OnContextCreated();
    }

    static void Main(string[] args)
    {
    AddExpenses();

       Console.WriteLine("Lazy loading is {0}.", 
                         _context.ContextOptions.LazyLoadingEnabled ? 
                         "enabled": "disabled");

       PrintCategorywiseExpenses();

   _context.Dispose();
       Console.WriteLine("Press any key to exit...");
   Console.ReadKey();
    }

 static void PrintCategorywiseExpenses()
    {
        foreach (var cateogry in _context.Categories)
        {
            Console.WriteLine
                            ("Category: {0}\n----------------", 
                             cateogry.CategoryName);

            foreach (var e in cateogry.Expenses)
                Console.WriteLine
                                    ("\tExpense: {0}\tAmount: {1}", 
                                     e.Particulars, e.Amount.ToString("C"));
        }

        Console.WriteLine();
    }

最佳答案

您应该知道,通过对导航属性执行 foreach,您明确要求 EF 为您加载它,仅仅因为您关闭延迟加载并不意味着您不能显式加载他们以后。因此,一旦它被禁用,您仍然可以根据需要显式加载相关数据,这正是您使用 foreach 时发生的情况。 “延迟加载” 的另一个术语实际上是“隐式延迟加载”,它不会阻止我们做“显式延迟加载”

基本上,这行代码:

foreach (var cateogry in _context.Categories)
几乎等同于:

_context.Categories.AsEnumerable()

要了解禁用延迟加载如何影响您的代码,请参见下面的示例。
在此示例中,我禁用它并读取您的一个类别,然后处理 ObjectContext 并在 Expenses 上执行 foreach:

Category category;
using (MyEntities context = new MyEntities()) {
    category = _context.Categories.First();
}

foreach (var e in cateogry.Expenses)
      Console.WriteLine("Expense:{0}", e.Amount.ToString("C"));
}


延迟加载已禁用:
没有任何反应,代码永远不会进入 foreach,因为 cateogry.Expenses.Count == 0

延迟加载已启用:
EF 尝试延迟加载 Expenses,并且由于 ObjectContext 已被释放(通过超出 using 范围),您将获得 System.ObjectDisposedException 包含此消息:
ObjectContext 实例已被释放,不能再用于需要连接的操作。

关于c# - 即使在 ObjectContext.ContextOptions.LazyLoadingEnabled = false 时也会延迟加载导航属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3990962/

相关文章:

c# - 在哪里可以找到有关在真实项目中使用 Entity Framework 的良好分步教程?

linq-to-entities - Entity Framework - 通过集合导航和包含属性

c# - 目前接受的使用 C# 4.0 从 SQL Server 检索数据的方法是什么?

c# - 用同一实体的不同实例替换上下文中的实体

C# CheckedListBox.ItemCheck 事件

c# - 如何在 Entity Framework 中有条件地生成DatabaseGenelated GUID

c# - EF 4 - 使用时间戳列更新表时出现异常

c# - 动态传递实体连接字符串 - 具有多个环境的多个实体

c# - 提高图像的打印质量

c# - WPF 多重绑定(bind) : OneWayToSource binding from TextBox updated via another binding doesnt work?