У меня есть запрос, извлекаемый из базы данных:
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 (и, вероятно, в конечном итоге это станет намного более читаемым в долгосрочной перспективе), но возможно ли это сделать? Может ли быть метод расширения для добавления специального предиката, чтобы это разрешить?