创建包含集合的EF 4迁移

时间:2012-06-16 02:10:31

标签: c# entity-framework entity-framework-4 ef-migrations

我正在尝试使用EF4为我的博客创建迁移,但我不确定如何声明这些字段是通用集合,例如Posts。如何才能做到这一点?使用intellesense时,没有可用于声明属性的泛型类型。

 CreateTable("Blogs", t => new
     {
         Id = t.Int(false, true),
         Title = t.String(),
         BloggerName = t.String(),
         Posts = t.ICollection<Post>()  //no ICollection
     }).PrimaryKey(k => k.Id);

1 个答案:

答案 0 :(得分:2)

我认为您首先在代码中将迁移与实体混合在一起,在这种情况下,您希望创建另一个名为“Posts”的表,该表与“Blogs”表具有外键关系。

 CreateTable("Posts", c => new
 {
     Id = c.Int(false, true),
     Content = c.String(nullable: false, maxLength: 512)
 }).PrimaryKey(k => k.Id)
 .ForeignKey("Blogs", t => t.Id);

通常更容易将实体构建为类(代码优先),然后让迁移工具在控制台中自行生成迁移,例如。

Add-Migration "BlogPosts"