使用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; }
}
}
答案 0 :(得分:0)
延迟加载对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 };
答案 1 :(得分:-1)
正如Yury Tarabanko的评论所说,返回的类别为空,因为您没有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”
的情况下生效