Несколько включений с использованием Entity Framework и шаблона репозитория.C#

Место общения программистов C#
Ответить
Anonymous
 Несколько включений с использованием Entity Framework и шаблона репозитория.

Сообщение Anonymous »

Я использую Entity Framework и шаблон репозитория для доступа ко всем данным. При использовании навигации по таблицам я заметил, что при получении первого объекта выполняются два запроса и ссылаются на поле в объекте навигации. Поскольку у меня много связей в базе данных, использование этого метода для моих свойств навигации может привести к снижению производительности.

Я изучил Include(string tableName) метод, и это будет работать очень хорошо (если бы я не использовал общий RP), но для этого требуется только одно имя таблицы. Мне удалось воспроизвести это в моем шаблоне репозитория для одного включения, изменив где с классов на EntityObject, но как я могу иметь несколько включений в один запрос, используя шаблон репозитория??
вот мой код:

public class GenericRepository : IRepository where T : EntityObject, new()
{
private Entities _Context;
private ObjectSet _ObjectSet;

public IQueryable FindBy(System.Linq.Expressions.Expression predicate, string include)
{
// This works OK
return this._ObjectSet.Include(include).Where(predicate);
}

public IQueryable FindBy(System.Linq.Expressions.Expression predicate, param string[] include)
{
// This will not work but is what I am trying to do
return this._ObjectSet.Include(include).Where(predicate);
}
}


Подробнее здесь: https://stackoverflow.com/questions/126 ... ry-pattern
Ответить

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

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

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

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

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