Есть ли лучший способ сделать это? Я попытался перебрать коллекцию partsToChange и создать предложение where, но оно объединяет их вместе вместо ORing. Я также не хочу явно делать равенство для каждого элемента в списке partsToChange.
var partsToChange = new Dictionary<string, string> {
{"0039", "Vendor A"},
{"0051", "Vendor B"},
{"0061", "Vendor C"},
{"0080", "Vendor D"},
{"0081", "Vendor D"},
{"0086", "Vendor D"},
{"0089", "Vendor E"},
{"0091", "Vendor F"},
{"0163", "Vendor E"},
{"0426", "Vendor B"},
{"1197", "Vendor B"}
};
var items = new List<MaterialVendor>();
foreach (var x in partsToChange)
{
var newItems = (
from m in MaterialVendor
where
m.Material.PartNumber == x.Key
&& m.Manufacturer.Name.Contains(x.Value)
select m
).ToList();
items.AddRange(newItems);
}
Дополнительная информация: я работаю в LINQPad, и это запрос LinqToSql. Здесь MaterialVendor является и классом, и таблицей DataContext.
Редактировать: детали LinqToSql.
Кажется, это лучший метод, который я нашел как для удобочитаемости, так и для уменьшения сложности. Это также имеет дополнительное преимущество, заключающееся в том, что тип коллекции не определен явно. Это означает, что я могу изменить то, что возвращается с анонимным типом.
var predicate = PredicateBuilder.False<MaterialVendor>();
foreach (var x in partsToChange)
{
var item = x;
predicate = predicate.Or (m =>
m.Material.PartNumber == item.Key
&& m.Manufacturer.Name.Contains(item.Value));
}
var items = from m in MaterialVendor.Where(predicate)
select m;