实体框架多对象关系

时间:2013-05-15 11:35:41

标签: c# linq entity-framework linq-to-entities

我有一个包含2个外键的表到同一个父表,Edge.StartStationId和Edge.EndStationId。

我正在尝试将theese映射到实体框架中的objets,但找不到似乎可以解决问题的解决方法。 我在父(站)上找到了一些使用2个集合的解决方案,我对此并不感兴趣。

站(父)班:

public partial class Station
{
    public Station()
    {
        this.Reservations = new List<Reservation>();
        this.StationMaintenances = new List<StationMaintenance>();
    }

    public int ID { get; set; } 
    public int TypeId { get; set; }
    public string Title { get; set; }
    public string Description { get; set; }
    public decimal StationLat { get; set; }
    public decimal StationLong { get; set; }
    public bool IsOperational { get; set; }
    public bool IsActive { get; set; }
    public DateTime CreatedDate { get; set; }
    public virtual BatteryStorage BatteryStorages { get; set; }
    public virtual List<Reservation> Reservations { get; set; }
    public virtual List<StationMaintenance> StationMaintenances { get; set; }
    public virtual List<Edge> Edges { get; set; }
    public virtual StationType StationType { get; set; }
}

Edge(孩子)课程:

public partial class Edge
{
    public int ID { get; set; }
    public int StartStationId { get; set; }
    public virtual Station StartStation { get; set; }
    public int EndStationId { get; set; }
    public virtual Station EndStation { get; set; }
    public decimal Distance { get; set; }
    public decimal Time { get; set; }
    public bool IsActive { get; set; }
}

边缘贴图类,在OnModelCreating中添加。

public EdgeMap()
{
    // Primary Key
    this.HasKey(t => t.ID);

    // Properties
    // Table & Column Mappings
    this.ToTable("Edges");
    this.Property(t => t.ID).HasColumnName("ID");
    this.Property(t => t.StartStationId).HasColumnName("StartStationId");
    this.Property(t => t.EndStationId).HasColumnName("EndStationId");
    this.Property(t => t.Distance).HasColumnName("Distance");
    this.Property(t => t.Time).HasColumnName("Time");
    this.Property(t => t.IsActive).HasColumnName("IsActive");

    // Relationships
    //this.HasOptional(t => t.StartStation)
    //    .WithMany(t => t.Edges)
    //    .HasForeignKey(d => d.StarStationId);
    //this.HasOptional(t => t.EndStation)
    //    .WithMany(t => t.Edges)
    //    .HasForeignKey(d => d.EndStationId);
}

例外:

  

在模型生成期间检测到一个或多个验证错误:   System.Data.Entity.Edm.EdmAssociationType ::多重性与关系“Edge_EndStation”中角色“Edge_EndStation_Target”中的参照约束冲突。由于从属角色中的所有属性都是不可为空的,因此主要角色的多重性必须为“1”。

1 个答案:

答案 0 :(得分:1)

我认为您发布的特定错误是抱怨HasOptional。由于外键(StartStationIdEndStationId)不可为空,因此它需要一个必需的映射。尝试将其更改为HasRequired,或将StartStationIdEndStationId的类型更改为int?,以便它知道导航属性可以为空。

至于Edges集合,它应包含哪些内容?使用EdgeStation值引用StartStationId的任何EndStationId?如果是这样,我认为你不能用一个集合来做到这一点。