1

当我们有这个 GenericRepository 类时,可以在实体框架中实现 FindBy 方法:

public class Repository<T> : IRepository<T> where T : class, IAggregateRoot
    {

        private readonly DbSet<T> _entitySet;
public IQueryable<T> FindBy(Expression<Func<T, bool>> predicate)
        {
            //IQueryable<T> query=_entitySet.
        }
}

在这种情况下如何实现 FindBy !??

4

2 回答 2

1

这应该工作

public class Repository<T> : IRepository<T> where T : class, IAggregateRoot
    {

        private readonly DbSet<T> _entitySet;
        public IQueryable<T> FindBy(Expression<Func<T, bool>> predicate)
        {
            return _entitySet.Where(predicate).
        }
}
于 2013-02-14T10:54:51.000 回答
1

My Repository 具有以下方法来通过给定表达式返回单个实体。

public T FindSingle(Expression<Func<T, bool>> predicate) {
  return _entitySet.FirstOrDefault(predicate);
}

现在调用者可以使用任何表达式来获取单个实体,例如

var entity = _repository.FindSingle(entity=> entity.Id == 23);

或者

var entity = _repository.FindSingle(entity=> entity.Name == "Hello World");

如果您的接口 IAggregateRoot 定义了一个属性 Id,您还可以向您的通用接口添加一个显式方法,以通过其 Id 获取单个实体。

public interface IAggregateRoot {
  int Id {get;}
}

public class GenericRepository {
  public T FindSingleById(int id) {
    return _entitySet.FirstOrDefault(entity=>entity.Id == id);
  }
}
于 2013-02-14T11:59:09.933 回答