当前位置:  开发笔记 > 编程语言 > 正文

EF Code First属性到同一个表

如何解决《EFCodeFirst属性到同一个表》经验,为你挑选了1个好方法。

我是EF的新手并且正在努力实现以下场景.我有一个实体,我想要一个导航属性到另一个相同的实体.例如

public class Stage {
    public int ID { get; set; }
    public int? NextStageID { get; set; }
    public string Name { get; set; }

    public virtual Stage NextStage { get; set;}
}

到目前为止,我发现的唯一例子是实体具有父/子关系,即导航属性是同一实体的ICollection.我试过调整它但是无法让它在我的实例中工作.此外,我只需要它是一种方式,即实体没有'PreviousStage'属性,只有'NextStage'属性.我正在使用Fluent API进行配置.有人可以建议是否/如何实现这一目标?

我收到此错误:

无法确定类型'namespace.Stage'和'namespace.Stage'之间关联的主要结尾.必须使用关系流畅API或数据注释显式配置此关联的主要结尾

编辑 刚刚在我的略微简化的例子中实现,我没有表明NextStageID是可选的(int?).



1> user449689..:

您可以按如下方式明确定义关系:

public class Stage {
    public int ID { get; set; }
    public int NextStageID { get; set; }
    public string Name { get; set; }

    [ForeignKey("NextStageID ")]
    public virtual Stage NextStage { get; set;}
}

推荐阅读
贴进你的心聆听你的世界
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有