线性中Where滤波器的动态变化

本文关键字:动态 变化 滤波器 Where 线性 | 更新日期: 2023-09-27 18:25:52

我正在尝试在我的应用程序中进行一些代码优化,并用一个方法替换几个做同样事情的方法。我有这个linq,我需要用各种过滤器执行,但我在中遇到了设计时错误。Where(filter)part

        Expression<Func<dbTable, bool>> filter;
        switch (i)
        {
            case 1: filter = (p => p.f1 == ExternalParam);
            case 2: filter = (p => p.f2 == ExternalParam);
        }
        var ds = (from tbl in dbEntities.dbTable
                  orderby tbl.f1
                  select new
                  {
                      f1 = tbl.f1,
                      f2 = tbl.f2,
                      f3 = tbl.f3,
                      f4 = tbl.f4,
                  }
                      ).Where(filter);

错误为

Error   1   'System.Linq.IQueryable<AnonymousType#1>' does not contain a definition for 'Where' and the best extension method overload 'System.Linq.Queryable.Where<TSource>(System.Linq.IQueryable<TSource>, System.Linq.Expressions.Expression<System.Func<TSource,int,bool>>)' has some invalid arguments    
Error   2   Argument 2: cannot convert from 'System.Linq.Expressions.Expression<System.Func<AppNameSpace.dbTable,bool>>' to 'System.Linq.Expressions.Expression<System.Func<AnonymousType#1,int,bool>>' 

有人能帮忙吗?

线性中Where滤波器的动态变化

好吧,您的表达式类型是Expression<dbTable, bool>

并且您尝试将其应用于anonymous类型(当您执行select new时,您正在投影到匿名类型),这…不是dbTable

因此,您应该将谓词应用于IQueryable<dbTable>:dbEntities.dbTable应该是那种类型。

    var ds = from tbl in dbEntities.dbTable.Where(filter)
              orderby tbl.f1
              select new
              {
                  f1 = tbl.f1,
                  f2 = tbl.f2,
                  f3 = tbl.f3,
                  f4 = tbl.f4,
              };

顺便说一句,我发现在不需要的时候避免混合语法更容易。

var ds = dbEntities.dbTable.Where(filter)
                           .OrderBy(m => m.f1)
                           .Select(m => new {
                              tbl.f1,
                              tbl.f2,
                              tbl.f3,
                              tbl.f4
                            });

但这部分只是一个个人PoV。