c# - "The * field is required"当EF对象已经有字段

标签 c# entity-framework ef-code-first entity-framework-6

我的数据模型如下:

[Table("Jobs")]
public abstract class Job
{
    public int Id { get; set; }
    public DateTime? StartTime { get; set; }
}

[Table("PbnJobs")]
public abstract class PbnJob : Job
{
    [Required]
    public virtual PbnSite Site{ get; set; }
    [ForeignKey("Site")]
    public int SiteId { get; set; }
}

[Table("DomainJobs")]
public class DomainJob : PbnJob
{
}

public class PbnSite
{
    public int Id { get; set; }
}

站点只是一个外键对象。

我的代码如下所示:

var context = new LmDbContext();
var job = context.Jobs.First();
job.StartTime = DateTime.Now;
_context.SaveChanges();

问题是,上面的代码抛出了异常类型

System.Data.Entity.Validation.DbEntityValidationException

,说:

"The Site field is required"

但是当我添加:

var site = ((PbnJob)job).Site;

编写代码:

var context = new LmDbContext();
var job = context.Jobs.First();
var site = ((PbnJob)job).Site;
job.StartTime = DateTime.Now;
_context.SaveChanges();

然后上下文就保存好了。

这里有什么问题?

编辑:顺便说一句,我正在使用代理和延迟加载。

最佳答案

你应该用必需的属性简单属性来标记,而不是导航属性:

[Table("PbnJobs")]
public abstract class PbnJob : Job
{
    public virtual PbnSite Site{ get; set; }

    [ForeignKey("Site")]
    [Required]
    public int SiteId { get; set; }
}

在这种情况下 Required 没有用,因为您的外键属性不可为空。

关于c# - "The * field is required"当EF对象已经有字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27554396/

相关文章:

c# - 将数据加载到 ListView (WPF)

c# - 如何使用 EWS 托管 API 回复电子邮件?

c# - Entity Framework 自连接

c# - 如何更改过滤器和外键列在 DynamicData 站点中的呈现方式?

c# - 使用 Entity Framework 和 WCF 的大型应用程序

entity-framework - Code First 迁移在 localdb 上更新了错误的 Db

c# - DataContract 无法序列化集合成员

c# - 跨多个应用程序域使用文件时读取\写入文件的最佳方式

asp.net-mvc-3 - DBContext、状态和原始值

c# - 导航属性和级联删除