c# – 为什么导航有时会返回null?
我有两个型号
public class Indicator { public long IndicatorID { get; set; } public string Name { get; set; } public int MaxPoint { get; set; } public string Comment { get; set; } public DateTime DateChanged { get; set; } public DateTime DateCreated { get; set; } public virtual IList<CalculationType> CalculationTypes { get; set; } } public class CalculationType { public long CalculationTypeID { get; set; } public string UnitName { get; set; } public int Point { get; set; } public DateTime DateCreated { get; set; } public DateTime DateChanged { get; set; } public virtual Indicator Indicator { get; set; } } 我有数据库工厂 public class DatabaseFactory { private StankinQuestionnaireEntities dataContext; public StankinQuestionnaireEntities Get() { return dataContext ?? (dataContext = new StankinQuestionnaireEntities()); } } 和属性,指的是databaseFactory protected StankinQuestionnaireEntities DataContext { get { return dataContext ?? (dataContext = DatabaseFactory.Get()); } } 我使用Autofac和regiser DatabaseFactory builder.RegisterType<DatabaseFactory>().As<IDatabaseFactory>().InstancePerRequest(); 在我的存储库中,我尝试以两种方式从导航属性获取数据 第一行工作正常(CalculationType包含一个元素) 但第二行在属性CalculationType上返回null 为什么? UPDATE UPDATE2由于某种原因,如果没有创建Proxy类 解决方法
您的数据库上下文肯定具有不同的ProxyCreationEnabled属性值.
如果查看截图中拾取的实体的类型,可以看到第一个类型为System.Data.Entity.DynamicProxies.Indicator_E …而第二个类型为StankinQuestionnaire.Model.Indicator. 这意味着对于第一个数据库上下文,ProxyCreationEnabled为true,对于第二个数据库上下文,属性为false.因此,延迟加载在第二种情况下不起作用. 尝试搜索项目中设置ProxyCreationEnabled的位置,可能您有多个位置. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |