Проблема с nHibernate Distinct и разбиением на страницы

У меня есть этот метод репозитория, который использует QueryOver API

    public IList<Message> ListMessagesBy(string text, IList<Tag> tags, int pageIndex, out int count, out int pageSize)
    {
        pageSize = 10;
        var likeString = string.Format("%{0}%", text);
        var query = session.QueryOver<Message>()
            .Where(Restrictions.On<Message>(m => m.Text).IsLike(likeString) ||
            Restrictions.On<Message>(m => m.Fullname).IsLike(likeString));

        if (tags.Count > 0)
        {
            var tagIds = tags.Select(t => t.Id).ToList();
            query
                .JoinQueryOver<Tag>(m => m.Tags)
                .WhereRestrictionOn(t => t.Id).IsInG(tagIds)
                .TransformUsing(Transformers.DistinctRootEntity);
        }                        

        count = 0;
        if(pageIndex < 0)
        {
            count = query.ToRowCountQuery().FutureValue<int>().Value;
            pageIndex = 0;
        }
        return query.OrderBy(m => m.Created).Desc.Skip(pageIndex * pageSize).Take(pageSize).List();
    }

. Я пробовал и

.TransformUsing(Transformers.DistinctRootEntity);

, и

.RootCriteria.SetResultTransformer(new DistinctEntityRootTransformer())

Он портит оба общего количества (он не возвращает отчетливый результат) и фактическое разбиение на страницы (Пропустить / взять)

Как я могу это исправить?

Заранее спасибо, Андерс

7
задан Anders 6 January 2011 в 19:00
поделиться