我有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);
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。