Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Transform LINQ IQueryable into a paged IQueryable using LINQ to NHibernate

I wanna do something like that

    public IQueryable GetPaged<TSource>(IQueryable<TSource> query, int startIndex, int pageSize)
    {
        return GetSession()
          .Linq<TSource>()
          .UseQuery(query)
          .Take(pageSize)
          .Skip(startIndex);
    }

So you can put any IQuerable statement and "it becomes paged" or it will be paged.

I am using LINQ to NHibernate. I hope you get it, sry for this bad english :o

edit: Maybe my approach is the wrong one, is it?

like image 943
Rookian Avatar asked Jan 09 '10 21:01

Rookian


1 Answers

This is copied from working code:

public static class QueryableExtensions
{   
    public static IQueryable<T> Paged<T>(this IQueryable<T> source, int page,
                                                                    int pageSize)
    {
        return source
          .Skip((page - 1) * pageSize)
          .Take(pageSize);
    }
}
like image 80
Paco Avatar answered Oct 19 '22 13:10

Paco