1

我怎样才能转换这个linq

from f in fake
join r in real
on f.Year equals r.Year
into joinResult
from r in joinResult.DefaultIfEmpty()
select (r == null ? f : r);

在具有方法形式的 Linq 中。

fake.Join(real, ...)

有没有工具可以帮助我做到这一点?

4

1 回答 1

1

这是 ReSharper 将其转换为的内容:

fake.GroupJoin(real, f => f.Year, r => r.Year, (f, joinResult) => new {f, joinResult})
    .SelectMany(@t => @t.joinResult.DefaultIfEmpty(), (@t, r) => (r == null ? @t.f : r));
于 2011-10-11T20:24:53.603 回答