加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 实体框架6没有导航属性的一对多关系

发布时间:2020-12-15 22:02:16 所属栏目:百科 来源:网络整理
导读:我有2个表:A和B有一对多的关系,这些表在EF 6中实现如下: public class A{ [Key] public int AID {get;set;} public string AName {get;set;}}public class B{ [Key] public int BID {get;set;} public string BName {get;set;} public int AID {get;set;}
我有2个表:A和B有一对多的关系,这些表在EF 6中实现如下:

public class A
{
    [Key]
    public int AID {get;set;}
    public string AName {get;set;}
}

public class B
{
    [Key]
    public int BID {get;set;}
    public string BName {get;set;}
    public int AID {get;set;}

    [ForeignKey("AID")]
    public A InstanceOfClassA {get;set;}
}

问题

当我从上下文中检索B时,InstanceOfClassA始终为null.

假设

因为没有导航属性参考A实体中的B,因此,实体框架在检索B时不会延迟加载A.

期待

因为我不需要从A访问B,所以我想摆脱A中的导航属性但是仍然保留了来自B的延迟加载A的能力.

注意

我在Map Many to Many relationship without navigation property看到一个帖子,但这不符合我的情况.

无论如何,我可以强制从B中延迟加载A而不使用显式include var b = context.B.Include(x => x.InstanceOfClassA);?也许定制会议

编辑1

我尝试使用惯例如下,仍然没有运气:

modelbuilder.Entity<B>()
    .HasRequired<A>(x => x.InstanceOfClassA);

解决方法

要使延迟加载工作,您必须使用virtual关键字标记navigation属性:

[ForeignKey("AID")]
public virtual A InstanceOfClassA {get;set;}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读