在EF Core中,表之间的外键关系可以通过在模型类中使用属性进行定义。当多个表之间有外键关系时,我们经常会遇到外键不正确的问题。下面是解决此问题的步骤和代码示例。
步骤:
1.在数据库上下文类中添加模型类的集合以便在迁移时创建表格。
public DbSet Orders { get; set; }
public DbSet Products { get; set; }
通过添加导航属性来定义外键关系:
public class Order { public int OrderId { get; set; } public int ProductId { get; set; } public int Quantity { get; set; }
public virtual Product Product { get; set; }
}
public class Product { public int ProductId { get; set; } public string Name { get; set; }
public virtual ICollection Orders { get; set; }
}
在DB上下文中覆盖OnModelCreating方法,以配置具有外键约束的实体关系。
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity
代码示例:
public class Order
{
public int OrderId { get; set; }
public int ProductId { get; set; }
public int Quantity { get; set; }
public virtual Product Product { get; set; }
}
public class Product
{
public int ProductId { get; set; }
public string Name { get; set; }
public virtual ICollection Orders { get; set; }
}
public class AppDbContext : DbContext
{
public DbSet Orders { get; set; }
public DbSet Products { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity()
.HasOne(p => p.Product)
.WithMany(b => b.Orders)
.HasForeignKey(p => p.ProductId);
}
}