当EF对象已经有字段时,“*字段是必需的”

时间:2014-12-18 19:40:21

标签: 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

,说:

  

"网站字段是必需的"

但是当我添加:

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();

然后保存上下文。

这里的问题是什么?

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

1 个答案:

答案 0 :(得分:1)

您应该使用必需属性标记简单属性,而不是导航属性:

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

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

在这种情况下,由于外键属性不可为空,因此必需。