Efficient Pagination with Skip/Take

Efficient pagination using OFFSET-FETCH on SQL Server.

Execution Time

39 ms

Page Size

25

Current Page

510 / 978

Total Records

24441

Items per page: 25 50 100 200

Page 510 Results Showing 12726 - 12750 of 24441

ID Name Category Price Stock Rating Reviews SKU
13285 Bulk Product a119b194 Books $720.71 71 3.2 69 BULK-43773f95
13286 Bulk Product 8f0938d6 Clothing $531.47 189 0.7 2 BULK-70429f1b
13287 Bulk Product 18836962 Toys & Games $520.82 262 2.1 87 BULK-613e2c74
13288 Bulk Product 36236863 Home & Garden $49.52 419 1.6 57 BULK-c3f7d474
13289 Bulk Product 905b46d8 Books $557.61 56 0.9 49 BULK-f62e6fef
13290 Bulk Product 9194fa7c Clothing $576.40 246 3.1 91 BULK-aced9b27
13291 Bulk Product 006d8cf5 Sports & Outdoors $787.15 273 4.1 88 BULK-ba2d7f01
13292 Bulk Product 329f5382 Home & Garden $106.68 21 3.0 12 BULK-24e00fdf
13293 Bulk Product 9491e85c Toys & Games $812.16 17 4.0 28 BULK-74684a1e
13294 Bulk Product 2934267e Sports & Outdoors $335.08 454 1.0 49 BULK-3ae4017c
13295 Bulk Product cbbf2dee Sports & Outdoors $987.21 413 1.1 5 BULK-a9353819
13296 Bulk Product 25cba54b Clothing $436.91 137 2.0 90 BULK-af800b63
13297 Bulk Product 5b97f9e5 Books $498.95 423 4.0 82 BULK-2155b9c0
13298 Bulk Product d862169e Toys & Games $19.71 414 1.0 19 BULK-05d13b5b
13299 Bulk Product cf256f7f Home & Garden $373.05 214 4.2 0 BULK-251e6823
13300 Bulk Product a4eef6bc Toys & Games $279.09 215 3.8 64 BULK-09419b7c
13301 Bulk Product bdb2178e Clothing $980.82 431 0.9 42 BULK-3c93d12d
13302 Bulk Product 2db36298 Home & Garden $942.41 338 1.1 19 BULK-9124d595
13303 Bulk Product eae92a5b Books $137.19 470 3.8 39 BULK-9e726162
13304 Bulk Product 1fb3ee32 Home & Garden $967.51 258 1.2 2 BULK-710d244b
13305 Bulk Product 61d822d1 Toys & Games $99.86 446 2.0 81 BULK-3070eeaf
13306 Bulk Product afd29d25 Toys & Games $505.89 15 0.5 2 BULK-1186324c
13307 Bulk Product 4f69dd17 Books $278.44 449 0.1 88 BULK-2dc20363
13308 Bulk Product 72326e65 Home & Garden $322.96 149 0.0 32 BULK-c5cfea50
13309 Bulk Product 2b6d0049 Clothing $841.01 135 0.7 95 BULK-e2bb4435
Implementation Code
// Efficient pagination with Skip and Take
public async Task<PaginatedResult<DemoProduct>> GetPaginatedProductsAsync(int page, int pageSize)
{
    // Get total count (cached if possible)
    var totalCount = await _context.DemoProducts.CountAsync(p => p.IsActive);
    
    // Get page of results
    var items = await _context.DemoProducts
        .Where(p => p.IsActive)
        .OrderBy(p => p.Id) // Important: Must have ORDER BY for consistent paging
        .Skip((page - 1) * pageSize) // OFFSET in SQL
        .Take(pageSize) // FETCH NEXT in SQL
        .AsNoTracking() // No tracking needed for read-only
        .ToListAsync();

    return new PaginatedResult<DemoProduct>
    {
        Items = items,
        TotalCount = totalCount,
        Page = page,
        PageSize = pageSize
    };
}
Pagination Best Practices
  • Always use OrderBy: Skip/Take require stable sorting for consistent results
  • Use AsNoTracking(): Pagination queries are typically read-only
  • Consider caching: Cache total count if dataset changes infrequently
  • Limit max page size: Prevent users from requesting too many records at once
  • Use indexed columns: Ensure ORDER BY columns are indexed for performance