В EF4 Code первая коллекция не загружается лениво? - PullRequest
4 голосов
/ 16 августа 2010

Использование Microsoft Visual C # 2010 Express, Entity Framework Feature 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 ]

0 голосов
/ 18 мая 2011

Ленивая загрузка не работает для 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 };
0 голосов
/ 16 августа 2010

, как говорится в комментарии Юрия Тарабанко, возвращаемая категория равна нулю, поскольку у вас нет идентификатора категории для c, поскольку она не была назначена.

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

c2.Products.Add(pr); 

будет работать, так как вы присвоили c.CategoryName со значением «Testcat»

...