Efficient Pagination with Skip/Take

Efficient pagination using OFFSET-FETCH on SQL Server.

Execution Time

14 ms

Page Size

25

Current Page

472 / 978

Total Records

24441

Items per page: 25 50 100 200

Page 472 Results Showing 11776 - 11800 of 24441

ID Name Category Price Stock Rating Reviews SKU
12335 Bulk Product 360f2cf6 Toys & Games $808.17 473 2.8 61 BULK-0e0aa711
12336 Bulk Product 8bc17685 Sports & Outdoors $45.22 409 2.5 78 BULK-8b46a712
12337 Bulk Product 7d38e808 Sports & Outdoors $245.29 62 4.4 45 BULK-2af28458
12338 Bulk Product 06c9e1f1 Books $91.20 14 0.4 11 BULK-9aac2a05
12339 Bulk Product 93fdac13 Clothing $306.56 280 4.1 28 BULK-41430236
12340 Bulk Product 85370750 Clothing $630.10 205 2.4 5 BULK-0b457996
12341 Bulk Product e7802521 Toys & Games $969.65 330 4.0 16 BULK-88d5a46d
12342 Bulk Product a0854d1d Electronics $383.12 306 4.5 1 BULK-8388b3e1
12343 Bulk Product 24b120cd Books $640.72 221 4.9 63 BULK-f9287184
12344 Bulk Product 3be97a2f Home & Garden $230.92 460 1.4 28 BULK-ecbe824f
12345 Bulk Product 5435cc09 Toys & Games $138.13 26 3.5 50 BULK-04076323
12346 Bulk Product 7ea8b3d1 Home & Garden $874.77 297 4.4 31 BULK-34c317b2
12347 Bulk Product 2cc9a092 Books $118.34 224 3.9 74 BULK-917c9cb6
12348 Bulk Product 18c998e7 Sports & Outdoors $307.92 415 2.0 79 BULK-9c7b1b90
12349 Bulk Product 7776ce4c Toys & Games $983.90 336 4.7 13 BULK-d3e351e8
12350 Bulk Product 3e821761 Books $82.20 240 4.3 29 BULK-fcdf449e
12351 Bulk Product 613e2819 Home & Garden $66.40 353 2.5 18 BULK-d016e8cc
12352 Bulk Product 39ad8b43 Sports & Outdoors $650.34 151 4.2 52 BULK-7809ed53
12353 Bulk Product 9a46a3ce Home & Garden $631.05 331 3.6 55 BULK-b0267049
12354 Bulk Product a41e0109 Clothing $832.13 359 2.8 55 BULK-66d027dc
12355 Bulk Product dfc029d7 Books $292.22 317 2.1 43 BULK-5f5ddd56
12356 Bulk Product f556531d Home & Garden $142.44 453 0.8 18 BULK-489228d5
12357 Bulk Product 3f402601 Sports & Outdoors $592.15 495 4.7 13 BULK-f8a349be
12358 Bulk Product 8dd455b2 Toys & Games $761.54 142 4.7 77 BULK-6694b040
12359 Bulk Product d7168903 Clothing $203.62 386 0.6 98 BULK-a4fbf8da
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