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()它们的两个查询.但是创建单个查询会更有效,而且看起来应该是可行的.

解决方法

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

查询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会给你一个抱怨无效参数的错误信息.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...