トラブルNLinqを持つエンティティ間での仕様の作成
-
26-09-2019 - |
質問
私は仕様のパターンを使用して、そしてNLinqを介してデータを取得するための作業を実施(WhoCanHelpMeのCodePlexプロジェクトから取られた)、一般的なリポジトリとすべてその良さを持っています。
ルート方法がある:
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プロパティでケースを照会するために、それはかなり単純明快です。 A私のための作品以下のような仕様と私がしたいと思うケースを取得します。
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); }
}
}
しかし、私は、複数のエンティティを横断するとき、これを行う方法を理解するためにロスでいます。私が持っているしたいことは、私はユーザー名でケースを取得することができます仕様です。基本的には、データベースに、3つのテーブルがあり、これらは、エンティティに搬入されています。ここのは実体があります:
ここではケースクラスがあります:
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; } }
}
どのように関連テーブル間でデータを取得するために、式を書くのでしょうか?
解決
私は信じてあなた仕様の実装は次のようになります。
public class CaseByUsernameSpecification : QuerySpecification<Case>
{
private string userName;
public CaseByUsernameSpecification(string userName)
{
this.userName = userName;
}
public string UserName
{
get { return this.userName; }
}
public override Expression<Func<Case, bool>> MatchingCriteria
{
get { return c => c.CaseUsers.Any(cu => cu.User.Username == this.userName); }
}
}
所属していません StackOverflow