Как построить собственный запрос PLINQO по нескольким идентификаторам? - PullRequest
0 голосов
/ 23 марта 2011

Вот моя структура таблицы

Места

  • PlaceId PK
  • Имя
  • ...

PlaceCategories

  • CatId PK
  • Имя
  • ...

PlaceCats

  • PlaceId PK
  • CatId PK

Вот мой запрос, который выбирает места на основе идентификатора категории (присоединение к таблице)

public static IQueryable<Places> ByPlaceCat(this Table<Places> table, Expression<Func<PlaceCats, bool>> predicate) {
    var db = (DataContext)table.Context;
    var innerBizBase = db.PlaceCats.Where(predicate);
    return db.Places.Join(innerBizBase, a => a.PlaceId, ab => ab.PlaceId, (a, ab) => a);
}

Я использую это так:

places = Db.Places.ByPlaceCat(a => a.CatId == 5);

Но я хочу иметь возможность тянуть на основе List<int> идентификаторов категорий.Просматривая сгенерированный код PLINQO, запрос, который обрабатывает несколько PlaceId (но не использует объединенную таблицу), выглядит следующим образом:

public static IQueryable<Places> ByPlaceId(this IQueryable<Places> queryable, IEnumerable<long> values)
{
    return queryable.Where(p => values.Contains(p.PlaceId));
}

Как я мог по существу объединить эти два запроса, чтобы позволить мне передатьList<int> CatId для запроса?Этот запрос LINQ / PLINQO растопил мой мозг.Заранее спасибо!

1 Ответ

3 голосов
/ 23 марта 2011

Вам нужно написать метод расширения, подобный этому:

    public static IQueryable<Places> ByPlaceCats(this Table<Places> table, IEnumerable<int> catIds)
    {
        var db = (TestDataContext)table.Context;
        var places = (from placeCat in db.PlaceCats
                      join place in db.Places on placeCat.PlaceId equals place.PlaceId
                      where catIds.Contains(placeCat.CatId)
                      select place);
        return places;
    }

Обратите внимание, что таблицу PlaceCats можно преобразовать в отношение ManyToMany , добавив два внешних ключа в соответствующие таблицы. После внесения этого изменения PLINQO автоматически сгенерирует правильный код и создаст ссылку между двумя таблицами, пропустив промежуточную таблицу. Таким образом, вы можете получить коллекцию PlaceCategories, связанную с текущей сущностью Places, обратившись к свойству в сущности Places.

Пожалуйста, не забудьте связаться с нами , если у вас есть какие-либо вопросы, и обязательно посетите форумы сообщества, расположенные здесь и Форумы PLINQO здесь .

Спасибо -Blake Niemyjski (поддержка CodeSmith)

...