Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/294.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 附加IQueryable和其他查询部分_C#_.net_Entity Framework_Linq - Fatal编程技术网

C# 附加IQueryable和其他查询部分

C# 附加IQueryable和其他查询部分,c#,.net,entity-framework,linq,C#,.net,Entity Framework,Linq,我有以下资料: IQueryable<Entity1, Entity2> query = //some query with joins return query.Distinct().ToList(); 但它返回相同的结果。有什么建议吗?.Concat(…)做一个联合。如果您只想添加一个谓词,那么只需将当前的query与query交换。其中(…) 你能解释一下为什么你需要query.Concat(query.Where?你正在向同一个集合中添加一些元素(创建一个副本)。但是在这之

我有以下资料:

IQueryable<Entity1, Entity2> query = //some query with joins
return query.Distinct().ToList();
但它返回相同的结果。有什么建议吗?

.Concat(…)
做一个联合。如果您只想添加一个谓词,那么只需将当前的
query
query交换。其中(…)


你能解释一下为什么你需要
query.Concat(query.Where
?你正在向同一个集合中添加一些元素(创建一个副本)。但是在这之后你需要
Distinct
。我不明白这个逻辑。你不能
Concat
对自己进行查询(你可以,但是结果会非常不直观)。如果您只想添加附加条件,只需添加一个
。其中
。如果您想使用相同的查询作为具有不同条件的实际联合操作的基础,事情会变得复杂,因为没有简单的“克隆”方法一个查询。您可能需要重新构造内容,以便只以不同方式构建
其中的
条件,而
查询
只构建一次。感谢您的帮助!我一开始尝试过,但没有成功。结果是我在代码中的其他地方犯了一个愚蠢的错误,一旦我修复了它,最简单的解决方案非常有效。Concat是ki这是一种过度的杀伤力,甚至让我无法正确理解:)
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();
var subquery = query.Concat(query.Where(some other conditions));
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();