我们可以使用Fluent API配置EF Core 一对一关系,使用HasOne-WithOne模式创建一对一关系,我们也可以使用EF Core约定来创建这种关系
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);
}
}
我们可以通过另外一种方法创建相同的关系
modelBuilder.Entity<CityInformation>()
.HasOne(e => e.City)
.WithOne(e => e.CityInformation)
.HasForeignKey<City>(e => e.CityInformationId);
EF Core 迁移过程会创建一对一的关系,会在City表中创建外键
说明
-
.WithOne(e =>e.CityInformation)配置关系,例如:CityInformation实体,表明CityInformation实体包含导航属性是City类型 -
.HasForeignKey(e => e.CityInformationId)表明外键列名称是CityInformationId
总结