Efficient Pagination with Skip/Take

Efficient pagination using OFFSET-FETCH on SQL Server.

Execution Time

19 ms

Page Size

25

Current Page

574 / 978

Total Records

24441

Items per page: 25 50 100 200

Page 574 Results Showing 14326 - 14350 of 24441

ID Name Category Price Stock Rating Reviews SKU
14885 Bulk Product 0735ca24 Electronics $893.33 280 3.6 93 BULK-1af9a142
14886 Bulk Product d93ba78b Home & Garden $886.17 340 0.4 12 BULK-9427a512
14887 Bulk Product 6e32b5c7 Sports & Outdoors $23.60 498 0.7 73 BULK-797c4c90
14888 Bulk Product 8a738c89 Books $985.26 318 1.4 24 BULK-c79399b4
14889 Bulk Product cb0a694b Toys & Games $97.28 183 3.4 41 BULK-fc7ca8f1
14890 Bulk Product 7cfca0ce Books $287.12 265 4.8 87 BULK-b231427c
14891 Bulk Product 00320250 Electronics $416.77 483 3.8 17 BULK-9e3253b3
14892 Bulk Product 14889b6b Clothing $742.24 486 2.0 37 BULK-3ed4da91
14893 Bulk Product 3bafe348 Sports & Outdoors $550.31 59 1.6 51 BULK-73eabe08
14894 Bulk Product d5c76039 Home & Garden $265.34 313 2.6 14 BULK-842d281c
14895 Bulk Product d744e09c Toys & Games $261.99 95 3.6 7 BULK-8145c119
14896 Bulk Product b44647fe Books $438.35 15 3.7 1 BULK-23510c1d
14897 Bulk Product 4779095e Sports & Outdoors $61.61 184 4.2 88 BULK-524101e8
14898 Bulk Product edd20dc3 Clothing $480.24 279 1.8 56 BULK-7decb8fd
14899 Bulk Product 6942cb13 Sports & Outdoors $83.93 269 0.9 4 BULK-ce23d629
14900 Bulk Product 2e7de875 Books $456.74 197 0.1 50 BULK-d4549724
14901 Bulk Product 062386bb Clothing $223.51 326 1.6 80 BULK-a3131b80
14902 Bulk Product bc5c2bc6 Books $845.43 249 1.2 42 BULK-574221e9
14903 Bulk Product ea6d8047 Sports & Outdoors $636.41 102 3.9 96 BULK-7d1198a4
14904 Bulk Product f51a8a0a Toys & Games $861.73 315 3.2 53 BULK-ac546b58
14905 Bulk Product 38a6d4bf Clothing $950.49 456 1.5 79 BULK-5851d86a
14906 Bulk Product d600268b Books $966.96 406 1.7 4 BULK-4364421d
14907 Bulk Product 21581580 Home & Garden $549.78 100 3.8 14 BULK-ea7bdd4b
14908 Bulk Product 6a6793e8 Books $455.57 423 3.4 73 BULK-7867ab9d
14909 Bulk Product 57bf2cc8 Home & Garden $268.21 315 2.6 74 BULK-8d894a5c
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