gpt4 book ai didi

c# - "EntityType has no key defined"异常,尽管键是用 HasKey 定义的

转载 作者:太空狗 更新时间:2023-10-29 20:34:03 24 4
gpt4 key购买 nike

使用 EF 5(首先对代码进行逆向工程),我的模型工作正常,直到它突然停止。

\tSystem.Data.Entity.Edm.EdmEntityType: : EntityType 'ProjectsDate' has no key defined. Define the key for this EntityType.

\tSystem.Data.Entity.Edm.EdmEntityType: : EntityType 'ProjectsRisk' has no key defined. Define the key for this EntityType.

我使用流畅的 API 而不是属性定义了一个键,这是我的 ProjectsDates 类。

public partial class ProjectsDate
{
public string OSProjectCode { get; set; }
public Nullable<System.DateTime> TargetStart { get; set; }
public Nullable<System.DateTime> EndDateOriginal { get; set; }
public Nullable<System.DateTime> EndDateChangeControl { get; set; }
public Nullable<System.DateTime> EndDateActual { get; set; }
public Nullable<System.DateTime> GoLiveAgreed { get; set; }
public Nullable<System.DateTime> GoLiveActual { get; set; }
public virtual Project Project { get; set; }
}
public class ProjectsDateMap : EntityTypeConfiguration<ProjectsDate>
{
public ProjectsDateMap()
{
// Primary Key
this.HasKey(t => t.OSProjectCode);

// Properties
this.Property(t => t.OSProjectCode)
.IsRequired()
.HasMaxLength(10);

// Table & Column Mappings
this.ToTable("ProjectsDates");
this.Property(t => t.OSProjectCode).HasColumnName("OSProjectCode");
this.Property(t => t.TargetStart).HasColumnName("TargetStart");
this.Property(t => t.EndDateOriginal).HasColumnName("EndDateOriginal");
this.Property(t => t.EndDateChangeControl).HasColumnName("EndDateChangeControl");
this.Property(t => t.EndDateActual).HasColumnName("EndDateActual");
this.Property(t => t.GoLiveAgreed).HasColumnName("GoLiveAgreed");
this.Property(t => t.GoLiveActual).HasColumnName("GoLiveActual");

// Relationships
this.HasRequired(t => t.Project)
.WithOptional(t => t.ProjectsDate);

}
}

为什么 EF 看不到我的 Fluent API 映射?

最佳答案

出于某种原因(可能是错误),FluentAPI 需要以约定方式定义 key - 即 - ClassName + Id,或者在您的情况下:

ProjectsDateId

这样,EF 创建的元数据就可以确认它是相关的。很烦人但是...

关于c# - "EntityType has no key defined"异常,尽管键是用 HasKey 定义的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16461941/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com