efcodefirst 一对多 非主键关联
时间: 2024-09-13 14:03:10 浏览: 86
EF Code First是Entity Framework的一个功能,它允许开发者通过定义实体类和它们之间的关系来自动生成数据库模式。在一对多(One-to-Many)关系中,一个实体(父实体)可以与多个其他实体(子实体)相关联,但每个子实体只能与一个父实体相关联。
在EF Code First中实现一对多非主键关联,通常需要在实体类中使用导航属性(Navigation Properties)和外键属性(ForeignKey Properties)。由于是“非主键关联”,我们不会使用父实体的主键作为子实体的主键,而是会创建一个额外的属性来表示这种关系。
例如,假设我们有一个博客(Blog)和多个帖子(Post)的场景:
```csharp
public class Blog
{
public int BlogId { get; set; } // Blog的主键
public string Url { get; set; }
// 一对多的导航属性(从Blog到Post)
public virtual ICollection<Post> Posts { get; set; }
}
public class Post
{
public int PostId { get; set; } // Post的主键
public string Title { get; set; }
public string Content { get; set; }
// 非主键关联的外键属性
public int BlogId { get; set; }
// 一对多的导航属性(从Post到Blog)
public virtual Blog Blog { get; set; }
}
```
在上面的代码中,`Blog` 类有一个名为 `Posts` 的集合属性,用于存储与该博客相关的所有帖子。`Post` 类有一个名为 `Blog` 的导航属性,用于指向它的父博客,同时包含一个 `BlogId` 属性作为外键来表示这种一对多的关系。
为了正确映射这种关系,还需要在 `DbContext` 的派生类中配置 `DbSet` 属性,并使用 Fluent API 或数据注解来指定关系配置:
使用 Fluent API 配置:
```csharp
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Blog>()
.HasMany(b => b.Posts)
.WithRequired(p => p.Blog)
.HasForeignKey(p => p.BlogId);
}
```
使用数据注解配置:
```csharp
public class Post
{
[ForeignKey("Blog")]
public int BlogId { get; set; }
public virtual Blog Blog { get; set; }
}
```
阅读全文