首页 > 解决方案 > 当依赖实体只有外键而没有主键时,两个实体之间的 C# EF 关系 0..1-1

问题描述

如何设置两个实体之间的 EF 关系,其中第一个(主)实体具有主键,但第二个(从属)没有 PK,只有外键 - 在第一个实体上。

public class Dogovor
{
    public int Key { get;set; }
    public string Name { get;set; }
    public virtual DogovorStatus Status { get; set; }
}

public class DogovorStatus
{
    public int StatusKey { get; set; }

    //public int DogovorKey { get; set; }  // - no need, because this key is pointed in DogovorConfiguration        
}

数据库表

我试图这样做,但没有成功:

public class DogovorConfiguration : EntityTypeConfiguration<Dogovor>
{
    HasKey(v => v.Key);
    Property(v => v.Key)
        .IsRequired()
        .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None)
        .HasColumnName("DG_Key");
    Property(v => v.Name).
        .IsRequired()
        .HasColumnName("DG_Name");

    HasOptional(v => v.Status)
        .WithRequired()
        .Map(v => v.MapKey("ST_DGKey"));
}

public class DogovorStatusConfiguration : EntityTypeConfiguration<DogovorStatus> {

HasKey(v => v.StatusKey);  // not unique - logical error
Property(v => v.StatusKey)
    .IsRequired()
    .HasColumnName("ST_StatusKey");
}

我无法将 PK 添加到 DogovorStatus。指出这种类型的 EF 关系的正确方法是什么?

英孚 6.0

标签: c#entity-frameworkentity-relationship

解决方案


也将导航属性添加到 DogovorStatus 类:

public class DogovorStatus
{
    public int StatusKey { get; set; }
    public virtual Dogovor Dogovor { get; set; }
}

然后调整配置:

public class DogovorStatusConfiguration : EntityTypeConfiguration<DogovorStatus> 
{
    HasKey(v => v.StatusKey);
}

public class DogovorConfiguration : EntityTypeConfiguration<Dogovor>
{
    HasKey(v => v.Key);
    Property(v => v.Key)
        .IsRequired()
        .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None)
        .HasColumnName("DG_Key");

    Property(v => v.Name)
        .IsRequired()
        .HasColumnName("DG_Name");

    HasOne(v => v.Status)
        .WithOne(s => s.Dogovor)
        .HasForeignKey<DogovorStatus>(s => s.StatusKey);
}

另请参阅配置一对一关系以供参考


推荐阅读