为什么导航 属性 有时 return 为空?
Why navigation propery sometimes return 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 和注册器 DatabaseFactory
builder.RegisterType<DatabaseFactory>().As<IDatabaseFactory>().InstancePerRequest();
在我的存储库中,我尝试通过两种方式从导航 属性 获取数据
第一行工作正常(CalculationType 包含一个元素)
但第二行 return 在 属性 CalculationType
上为空
为什么?
更新
我发现如果删除行“.InstancePerRequest()”,一切正常。但我不适合这个。
UPDATE2 出于某种原因,ef 未创建代理 class
试试这个:
DbContext.Configuration.ProxyCreationEnabled = true;
DbContext.Configuration.LazyLoadingEnabled = true;
如果DbContext.Configuration.ProxyCreationEnabled设置为false,DbContext将不会加载某些父对象的子对象,除非在父对象上调用Include方法。将 DbContext.Configuration.LazyLoadingEnabled 设置为 true 或 false 不会影响其行为。
如果DbContext.Configuration.ProxyCreationEnabled设置为true,子对象将自动加载,DbContext.Configuration.LazyLoadingEnabled值将控制何时加载子对象。
我认为这个 post 和这个是一样的:
您的数据库上下文肯定有不同的 ProxyCreationEnabled 属性 值。
如果您查看屏幕截图中所选实体的类型,您会发现第一个的类型为 System.Data.Entity.DynamicProxies.Indicator_E...,第二个的类型为 StankinQuestionnaire.Model.Indicator.
这意味着 ProxyCreationEnabled 对于第一个数据库上下文为真,而 属性 对于第二个数据库上下文为假。所以,延迟加载在第二种情况下不起作用。
尝试搜索在您的项目中设置 ProxyCreationEnabled 的位置,可能您有不止一个地方。
我有同样的问题,第一次加载页面时它工作正常,
当我刷新页面时,出现空引用异常。在我的例子中,我使用的是 Task
System.Threading.Tasks.Task.Run(() =>
{
});
此任务使用 Dbcontext 插入一条记录。我只是删除任务,一切都开始正常工作。
我有两个模型
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 和注册器 DatabaseFactory
builder.RegisterType<DatabaseFactory>().As<IDatabaseFactory>().InstancePerRequest();
在我的存储库中,我尝试通过两种方式从导航 属性 获取数据
第一行工作正常(CalculationType 包含一个元素)
但第二行 return 在 属性 CalculationType
上为空为什么?
更新 我发现如果删除行“.InstancePerRequest()”,一切正常。但我不适合这个。
UPDATE2 出于某种原因,ef 未创建代理 class
试试这个:
DbContext.Configuration.ProxyCreationEnabled = true;
DbContext.Configuration.LazyLoadingEnabled = true;
如果DbContext.Configuration.ProxyCreationEnabled设置为false,DbContext将不会加载某些父对象的子对象,除非在父对象上调用Include方法。将 DbContext.Configuration.LazyLoadingEnabled 设置为 true 或 false 不会影响其行为。
如果DbContext.Configuration.ProxyCreationEnabled设置为true,子对象将自动加载,DbContext.Configuration.LazyLoadingEnabled值将控制何时加载子对象。
我认为这个 post 和这个是一样的:
您的数据库上下文肯定有不同的 ProxyCreationEnabled 属性 值。
如果您查看屏幕截图中所选实体的类型,您会发现第一个的类型为 System.Data.Entity.DynamicProxies.Indicator_E...,第二个的类型为 StankinQuestionnaire.Model.Indicator.
这意味着 ProxyCreationEnabled 对于第一个数据库上下文为真,而 属性 对于第二个数据库上下文为假。所以,延迟加载在第二种情况下不起作用。
尝试搜索在您的项目中设置 ProxyCreationEnabled 的位置,可能您有不止一个地方。
我有同样的问题,第一次加载页面时它工作正常, 当我刷新页面时,出现空引用异常。在我的例子中,我使用的是 Task
System.Threading.Tasks.Task.Run(() =>
{
});
此任务使用 Dbcontext 插入一条记录。我只是删除任务,一切都开始正常工作。