Я использую Entity Framework 4.1
и repository pattern
.
Я пытаюсь создать методы, которые будут использоваться в большинстве сценариев. Я пытаюсь создать метод, который возвращает записи и сортирует их в соответствии с предоставленными критериями заказа. Можно отсортировать по 1, 2 или 3 столбцам. Я хочу, чтобы это было указано. Я нашел следующий код в Orchard framework
.
В IRepository interface
они имеют следующее (я оставил другие методы):
public interface IRepository<T>
{
IEnumerable<T> Fetch(Expression<Func<T, bool>> predicate);
IEnumerable<T> Fetch(Expression<Func<T, bool>> predicate, Action<Orderable<T>> order);
}
Реализация для IEnumerable<T> Fetch(Expression<Func<T, bool>> predicate, Action<Orderable<T>> order);
:
public class Repository<T> : IRepository<T>
{
public virtual IQueryable<T> Fetch(Expression<Func<T, bool>> predicate)
{
return Table.Where(predicate);
}
public virtual IQueryable<T> Fetch(Expression<Func<T, bool>> predicate, Action<Orderable<T>> order)
{
var orderable = new Orderable<T>(Fetch(predicate));
order(orderable);
return orderable.Queryable;
}
}
Orderable class
:
public class Orderable<T>
{
private IQueryable<T> _queryable;
public Orderable(IQueryable<T> enumerable)
{
_queryable = enumerable;
}
public IQueryable<T> Queryable
{
get { return _queryable; }
}
public Orderable<T> Asc<TKey>(Expression<Func<T, TKey>> keySelector)
{
_queryable = _queryable
.OrderBy(keySelector);
return this;
}
public Orderable<T> Asc<TKey1, TKey2>(Expression<Func<T, TKey1>> keySelector1,
Expression<Func<T, TKey2>> keySelector2)
{
_queryable = _queryable
.OrderBy(keySelector1)
.OrderBy(keySelector2);
return this;
}
public Orderable<T> Asc<TKey1, TKey2, TKey3>(Expression<Func<T, TKey1>> keySelector1,
Expression<Func<T, TKey2>> keySelector2,
Expression<Func<T, TKey3>> keySelector3)
{
_queryable = _queryable
.OrderBy(keySelector1)
.OrderBy(keySelector2)
.OrderBy(keySelector3);
return this;
}
public Orderable<T> Desc<TKey>(Expression<Func<T, TKey>> keySelector)
{
_queryable = _queryable
.OrderByDescending(keySelector);
return this;
}
public Orderable<T> Desc<TKey1, TKey2>(Expression<Func<T, TKey1>> keySelector1,
Expression<Func<T, TKey2>> keySelector2)
{
_queryable = _queryable
.OrderByDescending(keySelector1)
.OrderByDescending(keySelector2);
return this;
}
public Orderable<T> Desc<TKey1, TKey2, TKey3>(Expression<Func<T, TKey1>> keySelector1,
Expression<Func<T, TKey2>> keySelector2,
Expression<Func<T, TKey3>> keySelector3)
{
_queryable = _queryable
.OrderByDescending(keySelector1)
.OrderByDescending(keySelector2)
.OrderByDescending(keySelector3);
return this;
}
}
Таким образом, способ, которым это можно использовать, будет следующим:
var foos = _fooRepos.Fetch(
f => f.Name == "two" || f.Name == "three",
o => o.Asc(f => f.Name, f => f.Id)
);
Это лучший из возможных способов сделать то, чего я пытаюсь достичь? Я пытаюсь сделать это как можно проще. Буду признателен за любую помощь, а также, если есть пример кода и статьи.