如何使用QueryOver
并且没有公式字段来进行以下操作。
我有以下亲子关系
public class Club
{
public string Name { get; set; }
public IList<Membership> Memberships { get; set; }
}
public class Membership
{
public boolean Cancelled { get; set; }
public Club Club { get; set; }
}
我有以下查询返回15个俱乐部并将结果转换为DTO,我需要向该查询中添加RowCount
属于每个俱乐部但未被取消的会员资格。
IEnumerable<ClubIndexViewModelLineSummary> results = _querySession.QueryOver<Club>()
.OrderBy(c => c.IsActive).Desc
.OrderBy(c => c.Name).Asc
.SelectList(list => list
.Select(c => c.Id).WithAlias(() => sum.Id)
.Select(c => c.Name).WithAlias(() => sum.Name)
.Select(c => c.IsActive).WithAlias(() => sum.IsActive)
.Select(c => c.NumberOfWeeks).WithAlias(() => sum.NumberOfWeeks))
.TransformUsing(Transformers.AliasToBean<ClubIndexViewModelLineSummary>())
.Skip(start)
.Take(15)
.Future<ClubIndexViewModelLineSummary>();
经过更多研究,这是有效的结果查询:
Club clubAlias = null;
IEnumerable<ClubIndexViewModelLineSummary> results =
_querySession.QueryOver<Club>(() => clubAlias)
.OrderBy(c => c.IsActive).Desc
.OrderBy(c => c.Name).Asc
.SelectList(list => list
.Select(c => c.Id).WithAlias(() => sum.Id)
.Select(c => c.Name).WithAlias(() => sum.Name)
.Select(c => c.IsActive).WithAlias(() => sum.IsActive)
.Select(c => c.NumberOfWeeks).WithAlias(() => sum.NumberOfWeeks)
.SelectSubQuery
(
QueryOver.Of<ClubMembership>()
.Where(c => c.Canceled == false)
.And(c=> c.Club.Id == clubAlias.Id)
.ToRowCountQuery()
).WithAlias(()=> sum.ActiveMembers))
.TransformUsing(Transformers.AliasToBean<ClubIndexViewModelLineSummary>())
.Skip(start)
.Take(15)
.Future<ClubIndexViewModelLineSummary>();