标签:c ef-code-first entity-framework-6
我有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;}
标签:c,ef-code-first,entity-framework-6 来源: https://codeday.me/bug/20190708/1405819.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。