Подтвердить что ты не робот

Выражение LINQ ToListAsync с помощью DbSet

Я закодировал интернет-приложение С# MVC5 и задаюсь вопросом об использовании выражения .ToListAsync LINQ.

Вот мой код, который работает в результате действия индекса:

IEnumerable<IMapLocationItem> mapLocationImageGalleries = await db.mapLocationImageGalleries.Where(m => m.userName.Equals(userName)).ToListAsync();
IEnumerable<IMapLocationItem> mapLocationVideoGalleries = await db.mapLocationVideoGalleries.Where(m => m.userName.Equals(userName)).ToListAsync();
IEnumerable<IMapLocationItem> mapLocationItemsCombined = mapLocationImageGalleries.Concat(mapLocationVideoGalleries);

Я хочу создать служебную функцию для вышеуказанного кода. Вот что я закодировал:

public async Task<IEnumerable<IMapLocationItem>> GetAllMapLocationItemsFromUserName(string userName)
{
    IEnumerable<IMapLocationItem> mapLocationImageGalleries = await db.mapLocationImageGalleries.Where(m => m.userName.Equals(userName)).ToListAsync();
    IEnumerable<IMapLocationItem> mapLocationVideoGalleries = await db.mapLocationVideoGalleries.Where(m => m.userName.Equals(userName)).ToListAsync();
    IEnumerable<IMapLocationItem> mapLocationItemsCombined = mapLocationImageGalleries.Concat(mapLocationVideoGalleries);
    return mapLocationItemsCombined;
}

Я получаю следующую ошибку:

Error   17  'System.Linq.IQueryable<CanFindLocation.Models.MapLocationItems.MapLocationImageGallery>' does not contain a definition for 'ToListAsync' and no extension method 'ToListAsync' accepting a first argument of type 'System.Linq.IQueryable<CanFindLocation.Models.MapLocationItems.MapLocationImageGallery>' could be found (are you missing a using directive or an assembly reference?)

Точный же код отлично работает в результатах действия индекса, но не в методе обслуживания. Почему это и как я могу заставить это работать?

Заранее спасибо

4b9b3361

Ответ 1

Как отмечено в комментариях, добавьте using System.Data.Entity (в пакете Entity Framework), чтобы получить QueryableExtensions.

Для .NET Core эти методы находятся под Microsoft.EntityFrameworkCore