tôi có phương pháp Repository này trong đó sử dụng QueryOver APIVấn đề với nHibernate biệt và phân trang
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();
}
Tôi đã thử cả hai
.TransformUsing(Transformers.DistinctRootEntity);
và
.RootCriteria.SetResultTransformer(new DistinctEntityRootTransformer())
Nó vít lên cả tổng số đếm (Nó trả về kết quả không phân biệt) và phân trang thực tế (Bỏ qua/Thực hiện)
Làm cách nào để khắc phục sự cố này?
Cảm ơn trước, Anders
Giải thích về lý do tại sao/làm thế nào câu trả lời của bạn là đúng có thể hữu ích, thay vì chỉ 'Dưới đây là Các Codez' – sweaver2112