Linq To Sql несколько где поиск в цикле Foreach - PullRequest
3 голосов
/ 02 сентября 2011

Я пытаюсь отфильтровать таблицу, используя предложение where. Когда я пишу запросы отдельно, они работают нормально:

IQueryable<Movie> movies = db.Movies;
movies = movies.Where(movie =>
    movie.MovieToGenres.Any(genreItem => genreItem.Genre_ID == 34)
);
movies = movies.Where(movie =>
    movie.MovieToGenres.Any(genreItem => genreItem.Genre_ID == 35)
);

Однако я должен использовать его в цикле foreach:

List<int> genre_ids = new List<int>();
genre_ids.Add(34);
genre_ids.Add(35);

IQueryable<Movie> movies = db.Movies;
foreach (var genre_id in genre_ids)
{
   movies = movies.Where(movie =>
       movie.MovieToGenres.Any(genreItem => genreItem.Genre_ID == genre_id)
   );
}

Когда я это сделаю, на стороне SQL параметры запроса будут @p0 = 35, @p1 = 35 вместо @p0 = 34, @p1 = 35. Я не знаю почему.

Ответы [ 2 ]

5 голосов
/ 02 сентября 2011

Это еще один случай захвата переменной цикла .Есть только одна переменная genre_id, которая фиксируется всеми лямбда-выражениями.Это легко исправить, вводя новую переменную на каждой итерации и записывая ее вместо этого:

foreach (var genre_id in genre_ids)
{
   int genreCopy = genre_id;
   movies = movies.Where(movie => movie.MovieToGenres.Any(
                  genreItem => genreItem.Genre_ID == genreCopy));
}

В C # 5 это может быть ненужным - поведение вполне может меняться.

1 голос
/ 02 сентября 2011

Возможно, вы ищете что-то вроде этого

List<int> genres = new List<int>() { 34, 35, 36 };
movies = movies.Where(movie => movie.MovieToGenres.Any(genreItem => genres.Contains(genreItem.Genre_ID));

это должно выглядеть как IN ( 34, 35, 36)

...