Я пытался получить разные значения, используя Linq для NHibernate, и у меня ничего не получается.
Я пытался:
var query = from requesters in _session.Linq<Requesters>()
orderby requesters.Requestor ascending
select requesters;
return query.Distinct();
, а также
var query = from requesters in _session.Linq<Requesters>()
orderby requesters.Requestor ascending
select requesters;
return query.Distinct(new RequestorComparer());
Где RequestorComparer равен
public class RequestorComparer : IEqualityComparer<Requesters>
{
#region IEqualityComparer<Requesters> Members
bool IEqualityComparer<Requesters>.Equals(Requesters x, Requesters y)
{
//return x.RequestorId.Value.Equals(y.RequestorId.Value);
return ((x.RequestorId == y.RequestorId) && (x.Requestor == y.Requestor));
}
int IEqualityComparer<Requesters>.GetHashCode(Requesters obj)
{
return obj.RequestorId.Value.GetHashCode();
}
#endregion
}
Независимо от того, как я структурирую синтаксис, кажется, что он никогда не достигнет .Distinct()
.Без .Distinct()
в таблице, которую я запрашиваю, по умолчанию несколько дубликатов, порядка 195 записей, но должно быть возвращено только 22 различных значения.
Я не уверен, что делаюнеправильно, но очень признателен за любую помощь, которая может быть оказана.
Спасибо