标签:c asp-net asp-net-mvc entity-framework autofac
我有两个型号
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
我发现如果删除“.InstancePerRequest()”行,一切正常.但我不适合这个.
UPDATE2由于某种原因,如果没有创建Proxy类
解决方法:
您的数据库上下文肯定具有不同的ProxyCreationEnabled属性值.
如果查看截图中拾取的实体的类型,可以看到第一个类型为System.Data.Entity.DynamicProxies.Indicator_E …而第二个类型为StankinQuestionnaire.Model.Indicator.
这意味着对于第一个数据库上下文,ProxyCreationEnabled为true,对于第二个数据库上下文,属性为false.因此,延迟加载在第二种情况下不起作用.
尝试搜索项目中设置ProxyCreationEnabled的位置,可能您有多个位置.
标签:c,asp-net,asp-net-mvc,entity-framework,autofac 来源: https://codeday.me/bug/20190708/1401501.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。