У меня возникли проблемы при попытке преобразовать приведенный ниже запрос LINQ в один запрос:
// produces 8 results
var qryResults =
(from r in dbContext.Routes
join br in dbContext.BrokerRoutes on r.RouteId equals br.RouteId
join pr in dbContext.RoutePathFilters.Include(x => x.PathFilter) on r.RouteId equals pr.RouteId into paths
where br.Broker.ApiKey == apiKey
select new RouteTemplate
{
RouteId = r.RouteId,
Version = r.Version.Version,
Url = r.Url,
IsActive = r.IsActive,
Paths = paths.Select(x => x.PathFilter.FilterName).ToList()
})
.AsNoTracking()
.ToImmutableList();
// takes 8 results and turns that into 2 overall objects.
var results = new List<RouteTemplate>();
foreach (var r in qryResults)
{
if (results.All(x => x.RouteId != r.RouteId))
{
r.Paths = qryResults
.Where(x => x.RouteId == r.RouteId)
.Select(x => x.Paths.First()).ToList();
results.Add(r);
}
}
r
дублируется каждым значением, содержащимся в свойстве paths
.
Я знаю, что foreach можно объединить в приведенный выше запрос linq, но я пробовал уже несколько часов.Так что мне интересно знать, возможно ли это или нет и как это можно сделать?