Repository generic method GetById using eager loading

后端 未结 3 589
傲寒
傲寒 2021-01-23 22:33

I am using Entity Framework and would like to create generic GetById method in Repository class with eager loading:

Here is my method which uses lazy-lo

3条回答
  •  猫巷女王i
    2021-01-23 22:42

    One possible way is to use FirstOrDefault with predicate over the DbSet with Includes. It's not hard to build manually a predicate using Expression.Equal method, but the main challenge is how to get the key property name. Luckily we can use some ObjectContext methods to do that, so the implementation could be like this (assuming we have access to the concrete DbContext instance):

    public virtual TEntity GetById(object id, params string[] includeProperties)
    {
        var propertyName = ((System.Data.Entity.Infrastructure.IObjectContextAdapter)DbContext).ObjectContext
            .CreateObjectSet().EntitySet.ElementType.KeyMembers.Single().Name;
    
        var parameter = Expression.Parameter(typeof(TEntity), "e");
        var predicate = Expression.Lambda>(
            Expression.Equal(
                Expression.PropertyOrField(parameter, propertyName),
                Expression.Constant(id)),
            parameter);
    
        var query = DbSet.AsQueryable();
        if (includeProperties != null && includeProperties.Length > 0)
            query = includeProperties.Aggregate(query, System.Data.Entity.QueryableExtensions.Include);
        return query.FirstOrDefault(predicate);
    }
    

提交回复
热议问题