加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 为什么导航有时会返回null?

发布时间:2020-12-15 22:12:22 所属栏目:百科 来源:网络整理
导读:我有两个型号 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 Dat
我有两个型号

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的位置,可能您有多个位置.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读