我们可以使用Fluent API配置EF Core 一对一关系,使用HasOne-WithOne模式创建一对一关系,我们也可以使用EF Core约定来创建这种关系
让我们使用Fluent API在City和CityInformation之间一对一的关系
public class City
{
public int Id { get; set; }
public string Name { get; set; }
public int CityInformationId { get; set; }
public CityInformation CityInformation { get; set; }
}
public class CityInformation
{
public int Id { get; set; }
public int Population { get; set; }
public string OtherName { get; set; }
public string MayorName { get; set; }
public City City { get; set; }
}
City类有一个名为CityInformation导航属性
public CityInformation CityInformation { get; set; }
类似的,CityInformation有一个名为City的导航属性
public City City { get; set; }
接下来我们在 DbContext 内配置OnModelCreating 方法
public class CountryContext: DbContext
{
public DbSet<City> City { get; set; }
public DbSet<CityInformation> CityInformation { get; set; }
public CountryContext(DbContextOptions<CountryContext> options) : base(options)
{
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
//Write Fluent API configurations here
modelBuilder.Entity<City>()
.HasOne(e => e.CityInformation)
.WithOne(e => e.City)
.HasForeignKey<City>(e => e.CityInformationId);
}
}
在上面代码中,在City&CityInformation实体之间使用HasOne-WithOne模式创建一对一关系
我们可以通过另外一种方法创建相同的关系
modelBuilder.Entity<CityInformation>()
.HasOne(e => e.City)
.WithOne(e => e.CityInformation)
.HasForeignKey<City>(e => e.CityInformationId);
EF Core 迁移过程会创建一对一的关系,会在City表中创建外键
说明
modelBuilder.Entity() 开始配置一个City的实体类,HasOne(e => e.City)方法指定City实体类包含一个 CityInformation 的导航属性
.WithOne(e =>e.CityInformation)配置关系,例如:CityInformation实体,表明CityInformation实体包含导航属性是City类型
.HasForeignKey(e => e.CityInformationId)表明外键列名称是CityInformationId
总结
这节我们主要介绍了在EF Core中使用Fluent API配置一对一关系
源代码地址
https://github.com/bingbing-gui/Asp.Net-Core-Skill/tree/master/EntityFrameworkCore/EFCoreFluentAPIOneToOne