public class Command
{
public int CommandId { get; set; }
public string Title { get; set; }
public virtual ICollection<CommandPart> CommandParts { get; set; }
}
public class CommandPart
{
public int CommandPartID { get; set; }
public string part { get; set; }
public virtual ICollection<Command> command { get; set; }
}
public ViewResult Filter(string myString)
{
var foo = myString.Split(Convert.ToChar("+"));
var a = foo[0];
var b = foo[1];
var query =
db.Commands.Where(
c =>
c.CommandParts.Any(p => p.part == a)
&& (c.CommandParts.Any(p2 => p2.part == b))).ToList();
return View(query.ToList());
}
Запрос выше работает, как и ожидалось, когда в foo ровно два элемента.Я хотел бы иметь возможность перебрать foo для создания запроса.Вот моя попытка, но она не работает:
var foo = myString.Split(Convert.ToChar("+"));
IQueryable<Command> query = db.Commands;
foreach (var keyword in foo)
{
query = query.Where(c => c.CommandParts.Any(p => p.part == keyword));
}
Это проект ASP.NET MVC3, использующий Entity Framework.Как я могу написать запрос, чтобы он генерировался во время выполнения?