我们可以使用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 heremodelBuilder.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
总结