我正在尝试使用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);
答案 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"