【问题标题】:Append IQueryable with additional query parts使用附加查询部分附加 IQueryable
【发布时间】:2019-07-02 14:11:09
【问题描述】:

我有以下几点:

IQueryable<Entity1, Entity2> query = //some query with joins
return query.Distinct().ToList();

这很好用。我想要做的是通过添加一些额外的部分来扩展查询,如下所示:

IQueryable<Entity1, Entity2> query = //some query with joins
return query.Distinct().ToList();

if (something)
{
     query = query.Concat(query.Where(some conditions here));
}
else
{
     query = query.Concat(query.Where(some other conditions));
}

return query.Distinct().ToList();

不幸的是,在这种情况下,queryquery.Concat 之后为空。

我也试过了:

var subquery = query.Concat(query.Where(some other conditions));

但它返回相同的结果。有什么建议吗?

【问题讨论】:

  • 您能否解释一下为什么需要query.Concat(query.Where?您正在向同一个集合添加一些元素(创建重复项)。但在此之后你会做Distinct。我不明白这个逻辑
  • 您不能Concat 对自身进行查询(当然可以,但结果将非常不直观)。如果您只想添加其他条件,只需添加.Where。如果您想使用相同的查询作为具有不同条件的实际联合操作的基础,事情会变得复杂,因为没有简单的方法可以“克隆”查询。您可能需要重组事物,因此只有 Where 条件的构建方式不同,query 只构建一次。

标签: c# .net entity-framework linq


【解决方案1】:

.Concat(...) 全部合并。如果您只想添加一个谓词,那么只需将当前的queryquery.Where(...) 交换即可

IQueryable<Entity1, Entity2> query = //some query with joins

if (something)
{
     query = query.Where(some conditions here);
}
else
{
     query = query.Where(some other conditions);
}
return query.Distinct().ToList();

...您甚至可以使用查询语法。

var query = from e in yourDbContext.YourTable 
            select e;

if (something) 
{
    query = from e in query
            where someCondition
            select e;
}
return query.Distinct().ToList();

【讨论】:

  • 感谢您的帮助!我一开始尝试过,但没有奏效。原来我在代码的其他地方犯了一个愚蠢的错误,一旦我修复它,最简单的解决方案效果很好。 Concat 对此有点矫枉过正,甚至我没有正确理解它:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-11-16
  • 1970-01-01
  • 2014-08-17
  • 2016-06-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多