c# – Concat两个具有匿名类型的IQueryables?

前端之家收集整理的这篇文章主要介绍了c# – Concat两个具有匿名类型的IQueryables?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在和这个摔跤,现在看起来似乎不太可能.

我想要Concat()两个IQueryables,然后将结果作为单个查询执行.我试过这样的事情:

var query = from x in ...
select new
{
    A = ...
    B = ...
    C = ...
};

var query2 = from y in ...
select new
{
    A = ...
    B = ...
    C = ...
};

var query3 = query.Concat(query2);

但是,最后一行给出了以下错误

‘System.Linq.IQueryable’ does not contain a definition for ‘Concat’ and the best extension method overload ‘System.Linq.ParallelEnumerable.Concat(System.Linq.ParallelQuery,System.Collections.Generic.IEnumerable)’ has some invalid arguments

似乎它期待一个IEnumerable参数.有没有办法解决

看起来我可以解决IEnumerables和Concat()它们的两个查询.但是创建单个查询会更有效,而且看起来应该是可行的.

@H_404_17@解决方法
正如您之前在评论中所说,似乎两个查询返回不同的对象:

查询1(根据评论):

f__AnonymousTypee<Leo.Domain.FileItem,Leo.Domain.Employ‌​ee,int,string,string>

Query2是

f__AnonymousTypee<Leo.Domain.FileItem,L‌​eo.Domain.Employee,int?,string>

这就是为什么Concat会给你一个抱怨无效参数的错误信息.

猜你在找的C#相关文章