我有两个模型
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());
}
}
和引用数据库工厂的属性
protected StankinQuestionnaireEntities DataContext
{
get { return dataContext ?? (dataContext = DatabaseFactory.Get()); }
}
我使用Autofac和regiser DatabaseFactory
builder.RegisterType<DatabaseFactory>().As<IDatabaseFactory>().InstancePerRequest();
在我的存储库中,我尝试通过两种方式从导航属性获取数据
第一行工作正常(CalculationType包含一个元素)
但是第二行在属性CalculationType上返回null
为什么?
更新我发现,如果删除行“ .InstancePerRequest()”,则一切正常。但是我不适合这个。
UPDATE2由于某种原因,EF未创建代理类
您的数据库上下文肯定具有不同的ProxyCreationEnabled属性值。
如果在屏幕快照中查看所选择实体的类型,则可以看到第一个实体的类型为System.Data.Entity.DynamicProxies.Indicator_E ...,第二个实体的类型为StankinQuestionnaire.Model.Indicator。
这意味着ProxyCreationEnabled对于第一个数据库上下文为true,而对于第二个数据库属性为false。因此,延迟加载在第二种情况下不起作用。
尝试搜索项目中设置了ProxyCreationEnabled的位置,可能您有多个位置。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句