EF Core无法确定类型为“ ICollection <colourgroup>”的导航属性“ Colour.ColourGroups”表示的关系

时间:2019-04-05 00:08:46

标签: entity-framework-core ef-fluent-api

我在旧版数据库中有以下3个表。

CREATE TABLE Colour(
ColourCode char(3) NOT NULL,
CONSTRAINT PK_Colour PRIMARY KEY CLUSTERED 
(
    ColourCode ASC
)

CREATE TABLE ColourGroup(
    ColourGroup varchar(6) NOT NULL,
 CONSTRAINT PK_ColourGroup PRIMARY KEY CLUSTERED 
(
    ColourGroup ASC
)

CREATE TABLE Colour_ColourGroup(
    ColourCode char(3) NOT NULL,
    ColourGroup varchar(6) NOT NULL,
 CONSTRAINT PK_Colour_ColourGroup PRIMARY KEY CLUSTERED 
(
    ColourCode ASC,
    ColourGroup ASC
)

ALTER TABLE Colour_ColourGroup  WITH CHECK ADD  CONSTRAINT FK_Colour_ColourGroup_Colour FOREIGN KEY(ColourCode)
REFERENCES Colour (ColourCode)

ALTER TABLE Colour_ColourGroup  WITH CHECK ADD  CONSTRAINT FK_Colour_ColourGroup_ColourGroup FOREIGN KEY(ColourGroup)
REFERENCES ColourGroup (ColourGroup)

和以下EF类以代码表示它们

public class Colour
{
    public string ColourId { get; set; }

    public ICollection<ColourGroup> ColourGroups { get; set; }
}
public class ColourGroup
{
    public string ColourGroupId { get; set; }

    public ICollection<Colour> Colours { get; set; }
}
public class ColourColourGroup
{
    public string ColourId { get; set; }
    public string ColourGroupId { get; set; }

    public Colour Colour { get; set; }
    public ColourGroup ColourGroup { get; set; }

}

我正在使用Fluent API将ColourColourGroup链接到Colour_ColourGroup表并指定一些数据库列名称。

        builder.Entity<Colour>(entity =>
        {
            entity.Property(e => e.ColourId).HasColumnType("char(3)")
                   .HasColumnName("ColourCode");
            entity.Property(e => e.FinishId).HasMaxLength(3);
            entity.Property(e => e.Description).HasMaxLength(30);
            entity.HasKey(e => e.ColourId);
        });
        builder.Entity<ColourGroup>(entity =>
        {
            entity.Property(e => e.ColourGroupId).HasMaxLength(6)
                   .HasColumnName("ColourGroup");
            entity.HasKey(e => e.ColourGroupId);
        });
        builder.Entity<ColourColourGroup>(entity =>
        {
            entity.ToTable("Colour_ColourGroup");
            entity.Property(e => e.ColourGroupId).HasMaxLength(6)
                   .HasColumnName("ColourGroup");
            entity.Property(e => e.ColourId).HasMaxLength(3)
                   .HasColumnName("ColourCode");
            entity.HasKey(e => new { e.ColourId, e.ColourGroupId });
        });

但是我不知道如何将3个表链接在一起。如果只是Color和ColourGroup之间的一对多关系,我认为您应该在ColourGroup.Colours上使用InverseProperty(或任何Fluent等效项)。

任何访问这些实体的查询都会因上述错误而失败,例如:

var group = _context.ColourGroups.Where(g => g.ColourGroupId == "ALLPC").FirstOrDefault();

如何告诉EF Colour.ColourGroups和ColourGroup.Colours属性由ColourColourGroup中的相应属性“映射”?

0 个答案:

没有答案