В EF4 Code первая коллекция не загружается лениво?
Использование Microsoft Visual C# 2010 Express, функция Entity Framework CTP4.
Сначала я попробовал 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; }
}
}
2 ответа
Ленивая загрузка не работает для 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 };
Как говорится в комментарии Юрия Тарабанко, возвращаемая категория равна нулю, поскольку у вас нет идентификатора категории для c, поскольку он не был назначен.
var c2 = _db.Categories.SingleOrDefault(i => i.CategoryName == c.CategoryName);
var pr = new Product { ProductName = "testprod" };
c2.Products.Add(pr);
будет работать, так как вы назначили c.CategoryName со значением "Testcat"