我的数据模型如下:
[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();
然后保存上下文。
这里的问题是什么?
编辑:顺便说一句,我使用代理和延迟加载。
答案 0 :(得分:1)
您应该使用必需属性标记简单属性,而不是导航属性:
[Table("PbnJobs")]
public abstract class PbnJob : Job
{
public virtual PbnSite Site{ get; set; }
[ForeignKey("Site")]
[Required]
public int SiteId { get; set; }
}
在这种情况下,由于外键属性不可为空,因此必需。