繁体   English   中英

如何动态访问 DbSet 类型

[英]How to access DbSet type dynamically

我正在使用 LINQ 表达式来动态构建 select 和 where 表达式。

选择方法如下所示:

public Expression<Func<TSource, TTarget>> GetSelectExpression<TSource, TTarget>()
    {
        ParameterExpression l_pe = Expression.Parameter(Base_type, "source");  
...            
        Expression<Func<TSource, TTarget>> l_return = Expression.Lambda<Func<TSource, TTarget>>(l_select, new ParameterExpression[] { l_pe });
        l_return.Compile();

        return l_return;
    }

Where 方法如下所示:

public Expression<Func<TTarget, bool>> GetWhereExpression<TTarget>()
    {
        ParameterExpression l_pe = Expression.Parameter(Dto_type, "dto");

        ....

        Expression<Func<TTarget, bool>> l_return = Expression.Lambda<Func<TTarget, bool>>(l_or, new ParameterExpression[] { l_pe });
        l_return.Compile();

        return l_return;
    }

如果我调用以下语句,则一切正常:

var l_where = GetWhereExpression<CrudChangetaskDto>();
var l_select = GetSelectExpression<A_Changetask, CrudChangetaskDto>();               

IQueryable<CrudChangetaskDto> l_query = l_db.A_Changetask.Select(l_select).Where(l_where);
var lt_result = l_query.ToList();

由于更动态地使用 WHERE 和 SELECT 方法,我喜欢有一个返回 IQueryable 的方法,如下所示(PaltrConnect 是数据库上下文):

IQueryable<TTarget> GetSearchhelpvalue<TSource, TTarget>(PaltrConnect context)
    {   
        var l_dbset = context.Set(typeof(TSource));            

        IQueryable<TTarget> l_query = l_dbset.Select(GetSelectExpression<TSource,TTarget>()).Where(GetWhereExpression<TTarget>());
        return l_query;
    }

不幸的是,这在语法上是不正确的。 我收到错误消息 System.Linq.IQueryable 无法转换为 System.Linq.IQueryable。

最后,我喜欢通过以下方式调用 GetSearchhelpvalue:

using (var l_db = new PaltrConnect)
  {
    IQueryable<CrudChangeTaskDto> l_query = GetSearchhelpvalue<A_Changetask, CrudChangetaskDto>(l_db);
    var lt_result = l_query.ToList();
  }

如何访问与 TSource 对应的类型的 DbSet 或者如何解决?

你的斯蒂芬

你是如此接近。 只是代替非通用DbContext.Set(Type)使用通用DbContext.Set<TEntity>() 重载这样

IQueryable<TTarget> GetSearchhelpvalue<TSource, TTarget>(PaltrConnect context)
    where TSource : class
{   
    return context.Set<TSource>()            
        .Select(GetSelectExpression<TSource,TTarget>())
        .Where(GetWhereExpression<TTarget>());
}

请注意,它需要class约束。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM