Как установить свойства для всех элементов из запроса linq со значениями из другого объекта, который также извлекается из запроса?

У меня есть запрос, извлекаемый из базы данных:

List<myClass> items = new List<myClass>(from i in context
                      select new myClass
                      {
                          A = i.A,
                          B = "",    // i doesn't know this, this comes from elsewhere
                          C = i.C
                      }

У меня также есть другой запрос, делающий аналогичную вещь:

List<myClass2> otherItems = new List<myClass2>(from j in context
                            select new myClass2
                            {
                                A = j.A,   // A is the intersection, there will only be 1 A here but many A in items
                                B = j.B
                            }

В действительности эти классы намного больше и данные запроса, которые разделены не только базой данных, но и сервером. Можно ли использовать запрос LINQ для заполнения свойства B для всех items, где items.A пересекаются? Все встроенные предикаты LINQ отображаются только для выполнения агрегатов, выборок или выражений bool.

В моем мозгу у меня было что-то вроде этого, но это все выключено:

items.Where(x => x.B = (otherItems.Where(z => z.A == x.A).Single().B));

Или я смехотворно пытаюсь сделать эту работу в LINQ и должен просто отказаться от нее в пользу цикла for, где фактическая настройка становится тривиальной? Из-за крайних сроков я буду прибегать к циклу for (и, вероятно, в конечном итоге это станет намного более читаемым в долгосрочной перспективе), но возможно ли это сделать? Может ли быть метод расширения для добавления специального предиката, чтобы это разрешить?

Ответ 1

LINQ предназначен для запросов. Если вы пытаетесь установить что-то, вам обязательно нужно использовать цикл (возможно, foreach). Это не означает, что вы не сможете использовать LINQ как часть этого цикла, но вы не должны пытаться применить побочный эффект в самом LINQ.

Ответ 2

Сначала запросите OtherItems. Сделайте результат ToDictionary(). Затем при запросе базы данных сделайте следующее:

var items = from i in context
   select new myClass 
   { A = i.A, 
     B = otherItems[i.A], 
     C = i.C
   }