【问题标题】:In EF4 Code first Collection are not lazy loading?在 EF4 Code first Collection 中不是延迟加载吗?
【发布时间】:2011-05-18 21:59:25
【问题描述】:

使用 Microsoft Visual C# 2010 Express,实体框架功能 CTP4。

我首先使用基于 Scott Gu's blog 的小代码尝试了 EF4。但是在检索实体时似乎没有初始化集合。将产品添加到类别时出现空引用异常。在我见过的所有示例中,集合从未显式初始化。我错过了什么?

这是我的代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Entity;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            var _db = new Northwind();

            var c = new Category { CategoryName = "Testcat" };
            _db.Categories.Add(c);
            _db.SaveChanges();

            var c2 = _db.Categories.SingleOrDefault(i => i.CategoryId==c.CategoryId);
            var pr = new Product { ProductName = "testprod" };

            c2.Products.Add(pr);    //  <---  Null reference for Products

            _db.SaveChanges();

            Console.WriteLine("Done...");

            Console.ReadKey();
        }
    }

    public class Product
    {
        public int ProductId { get; set; }
        public string ProductName { get; set; }
        public virtual Category Category { get; set; }
    }

    public class Category
    {
        public int CategoryId { get; set; }
        public string CategoryName { get; set; }
        public virtual ICollection<Product> Products { get; set; }
    }

    public class Northwind : DbContext
    {
        public DbSet<Category> Categories { get; set; }
        public DbSet<Product> Products { get; set; }
    }

}

【问题讨论】:

  • 据我所知,问题是c2 为空,因为您的查询将返回默认为空的Category
  • DbContext 将 Id 映射到自动生成的 Id。在 savechanges() 之后,ID 被填充。 C2 不为空(我检查过)。但是产品是空的。
  • 你可以尝试做显式加载_db.Categories.Include("Products").SingleOrDefault(...)

标签: entity-framework entity-framework-4 lazy-loading code-first


【解决方案1】:

延迟加载不适用于 POCO。你需要一个代理。你可以通过替换得到这个

var c = new Category { CategoryName = "Testcat" };

var c = _db.Categories.Create();
c.CategoryName = "Testcat";

您的另一个选择仍然是使用没有代理的 POCO 并自己创建此列表并替换

c2.Products.Add(pr);

c2.Products = new List<Product> { pr };

【讨论】:

  • 谢谢,我也知道了,但现在我可以结束这个问题了。
【解决方案2】:

正如 Yury Tarabanko 的评论所说,返回的类别为 null,因为您没有 c 的类别 ID,因为它尚未分配。

var c2 = _db.Categories.SingleOrDefault(i => i.CategoryName == c.CategoryName);
var pr = new Product { ProductName = "testprod" };

c2.Products.Add(pr); 

因为您为 c.CategoryName 分配了“Testcat”的值,所以会起作用

【讨论】:

  • 查看我对 Yuri 的评论,在 SaveChanges() 之后,ID 是自动生成的。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-07-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多