Могу ли я использовать несколько объектов EF в IQueryable для реализации разбиения по страницам?C#

Место общения программистов C#
Ответить
Anonymous
 Могу ли я использовать несколько объектов EF в IQueryable для реализации разбиения по страницам?

Сообщение Anonymous »

У меня есть метод Get с рабочей разбивкой по страницам, но я также хочу создать метод, который может возвращать несколько сущностей одного и того же базового типа и при этом иметь разбиение на страницы.
Я знаю, что это нужно каким-то образом преобразовать в SQL, который, как я думаю, должен будет быть возвращен в виде нескольких наборов результатов.
// Model classes
public class Food
{
string Name {get;set;}
}

public class Fruit : Food
{
bool IsSweet {get;set;}
}

public class Vegetable : Food
{
bool IsGross {get;set;}
}

// FruitRepo -- BLL layer
public List GetFruit(int userId, int page, int itemsPerPage)
{
var query = repo.Get(e => e.userId == userId);
var dbResults = query.Skip((itemsPerPage * page) - itemsPerPage).Take(itemsPerPage).ToList();
return dbResults;
}

// FoodRepo -- BLL layer
public List GetFood(int userId, int page, int itemsPerPage)
{
// How can I use IQueryable here to implement paging correctly?

List rv = new List();

var repo = new Repo();
rv.AddRange(repo.Get(e => e.userId == userId).ToList());
rv.AddRange(repo.Get(e => e.userId == userId).ToList());

return rv;
}


Подробнее здесь: https://stackoverflow.com/questions/479 ... ent-paging
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»