Solving “The ObjectContext instance has been disposed and can no longer be used for operations that require a connection” InvalidOperationException

前端 未结 7 2285
再見小時候
再見小時候 2020-11-22 06:38

I am trying to populate a GridView using Entity Frameworkm but every time I am getting the following error:

\"Property accessor \'LoanPro

7条回答
  •  情书的邮戳
    2020-11-22 06:41

    By default Entity Framework uses lazy-loading for navigation properties. That's why these properties should be marked as virtual - EF creates proxy class for your entity and overrides navigation properties to allow lazy-loading. E.g. if you have this entity:

    public class MemberLoan
    {
       public string LoandProviderCode { get; set; }
       public virtual Membership Membership { get; set; }
    }
    

    Entity Framework will return proxy inherited from this entity and provide DbContext instance to this proxy in order to allow lazy loading of membership later:

    public class MemberLoanProxy : MemberLoan
    {
        private CosisEntities db;
        private int membershipId;
        private Membership membership;
    
        public override Membership Membership 
        { 
           get 
           {
              if (membership == null)
                  membership = db.Memberships.Find(membershipId);
              return membership;
           }
           set { membership = value; }
        }
    }
    

    So, entity has instance of DbContext which was used for loading entity. That's your problem. You have using block around CosisEntities usage. Which disposes context before entities are returned. When some code later tries to use lazy-loaded navigation property, it fails, because context is disposed at that moment.

    To fix this behavior you can use eager loading of navigation properties which you will need later:

    IQueryable query = db.MemberLoans.Include(m => m.Membership);
    

    That will pre-load all memberships and lazy-loading will not be used. For details see Loading Related Entities article on MSDN.

提交回复
热议问题