gpt4 book ai didi

entity-framework - 在 EF4 Code first Collection 是不是懒加载?

转载 作者:行者123 更新时间:2023-12-01 06:51:31 25 4
gpt4 key购买 nike

使用 Microsoft Visual C# 2010 Express, Entity Framework 功能 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; }
}

}

最佳答案

延迟加载不适用于 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 };

关于entity-framework - 在 EF4 Code first Collection 是不是懒加载?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3492192/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com