微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

原文地址:https://www.jb51.cc/csharp/243906.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐