4

Microsoft Visual C# 2010 Express、Entity Framework Feature CTP4 を使用。

Scott Gu の blogに基づいて、最初に小さなコードで EF4 を試しました。しかし、エンティティを取得するときにコレクションが初期化されていないようです。製品をカテゴリに追加すると、null 参照例外が発生します。私が見たすべての例で、コレクションが明示的に初期化されることはありません。私は何が欠けていますか?

これが私のコードです:

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; }
    }

}
4

2 に答える 2

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 };
于 2011-05-18T13:59:25.223 に答える
-1

Yury Tarabanko のコメントにあるように、割り当てられていないため c のカテゴリ ID がないため、返されるカテゴリは null です。

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

c2.Products.Add(pr); 

c.CategoryName に「Testcat」の値を割り当てたため、機能します

于 2010-08-16T17:49:30.280 に答える