Я использую шаблон спецификации и у меня есть рабочая реализация (взятая из проекта WhoCanHelpMe Codeplex) для получения данных через NLinq, универсальные репозитории и все такое.
Корневой метод:
public IList<Case> GetCasesByUsername(string username)
{
CaseByUserNameSpecification spc = new CaseByUserNameSpecification(username);
return this.caseRepository.FindAll(spc).ToList();
}
Метод FindAll () делает следующее:
public IQueryable<T> FindAll(ILinqSpecification<T, T> specification)
{
return specification.SatisfyingElementsFrom(this.Session.Linq<T>());
}
И, SatisfyingElementsFrom () делает это:
public virtual IQueryable<TResult> SatisfyingElementsFrom(IQueryable<T> candidates)
{
if (this.MatchingCriteria != null)
{
return candidates.Where(this.MatchingCriteria).ToList().ConvertAll(this.ResultMap).AsQueryable();
}
return candidates.ToList().ConvertAll(this.ResultMap).AsQueryable();
}
Итак, для запроса случаев по свойству CaseNb свойстваСлучай, это довольно просто.Спецификация, подобная приведенной ниже, работает для меня и позволяет получить нужные мне случаи.
public class CaseByCaseNbSpecification : QuerySpecification<User>
{
private string caseNb;
public CaseByCaseNbSpecification(string caseNb)
{
this.caseNb = caseNb;
}
public string UserName
{
get { return this.caseNb; }
}
public override Expression<Func<Case, bool>> MatchingCriteria
{
get { return u => u.CaseNb.Equals(this.caseNb, StringComparison.CurrentCultureIgnoreCase); }
}
}
Однако я затрудняюсь понять, как это сделать при пересечении нескольких объектов.То, что я хотел бы иметь, является Спецификацией, которая позволяет мне получать Случаи по Имени пользователя.По сути, в базе данных есть три таблицы, и они были перенесены в сущности.Вот сущности:
Вот класс Case:
public class Case : Entity
{
private ICollection<CaseUser> caseUsers = new HashSet<CaseUser>();
public virtual Patient Patient { get; set; }
public virtual string CaseNb { get; set; }
...
public virtual IEnumerable<CaseUser> CaseUsers { get { return caseUsers; } }
}
Вот CaseUser:
public class CaseUser : Entity
{
public virtual Case Case { get; set; }
public virtual User User { get; set; }
...
}
И, пользователь:
public class User : Entity
{
private ICollection<CaseUser> caseUsers = new HashSet<CaseUser>();
public virtual Account Account { get; set; }
public virtual string UserName { get; set; }
...
public virtual IEnumerable<CaseUser> CaseUsers { get { return caseUsers; } }
}
Как бы я написал выражение, чтобы получить данные через таблицу ассоциации?